JUCE-7.0.12-0-g4f43011b96 JUCE-7.0.12-0-g4f43011b96
JUCE — C++ application framework with suport for VST, VST3, LV2 audio plug-ins

« « « Anklang Documentation
Loading...
Searching...
No Matches
Public Types | Public Member Functions | List of all members
juce::dsp::LinkwitzRileyFilter< SampleType > Class Template Reference

A filter class designed to perform multi-band separation using the TPT (Topology-Preserving Transform) structure. More...

#include "juce_LinkwitzRileyFilter.h"

Public Types

using Type = LinkwitzRileyFilterType
 

Public Member Functions

 LinkwitzRileyFilter ()
 Constructor.
 
void setType (Type newType)
 Sets the filter type.
 
void setCutoffFrequency (SampleType newCutoffFrequencyHz)
 Sets the cutoff frequency of the filter in Hz.
 
Type getType () const noexcept
 Returns the type of the filter.
 
SampleType getCutoffFrequency () const noexcept
 Returns the cutoff frequency of the filter.
 
void prepare (const ProcessSpec &spec)
 Initialises the filter.
 
void reset ()
 Resets the internal state variables of the filter.
 
template<typename ProcessContext >
void process (const ProcessContext &context) noexcept
 Processes the input and output samples supplied in the processing context.
 
SampleType processSample (int channel, SampleType inputValue)
 Performs the filter operation on a single sample at a time.
 
void processSample (int channel, SampleType inputValue, SampleType &outputLow, SampleType &outputHigh)
 Performs the filter operation on a single sample at a time, and returns both the low-pass and the high-pass outputs of the TPT structure.
 
void snapToZero () noexcept
 Ensure that the state variables are rounded to zero if the state variables are denormals.
 

Detailed Description

template<typename SampleType>
class juce::dsp::LinkwitzRileyFilter< SampleType >

A filter class designed to perform multi-band separation using the TPT (Topology-Preserving Transform) structure.

Linkwitz-Riley filters are widely used in audio crossovers that have two outputs, a low-pass and a high-pass, such that their sum is equivalent to an all-pass filter with a flat magnitude frequency response. The Linkwitz-Riley filters available in this class are designed to have a -24 dB/octave slope (LR 4th order).

@tags{DSP}

Definition at line 48 of file juce_LinkwitzRileyFilter.h.

Member Typedef Documentation

◆ Type

template<typename SampleType >
using juce::dsp::LinkwitzRileyFilter< SampleType >::Type = LinkwitzRileyFilterType

Definition at line 52 of file juce_LinkwitzRileyFilter.h.

Constructor & Destructor Documentation

◆ LinkwitzRileyFilter()

template<typename SampleType >
juce::dsp::LinkwitzRileyFilter< SampleType >::LinkwitzRileyFilter ( )

Constructor.

Definition at line 31 of file juce_LinkwitzRileyFilter.cpp.

Member Function Documentation

◆ getCutoffFrequency()

template<typename SampleType >
SampleType juce::dsp::LinkwitzRileyFilter< SampleType >::getCutoffFrequency ( ) const
noexcept

Returns the cutoff frequency of the filter.

Definition at line 70 of file juce_LinkwitzRileyFilter.h.

◆ getType()

template<typename SampleType >
Type juce::dsp::LinkwitzRileyFilter< SampleType >::getType ( ) const
noexcept

Returns the type of the filter.

Definition at line 67 of file juce_LinkwitzRileyFilter.h.

◆ prepare()

template<typename SampleType >
void juce::dsp::LinkwitzRileyFilter< SampleType >::prepare ( const ProcessSpec spec)

Initialises the filter.

Definition at line 54 of file juce_LinkwitzRileyFilter.cpp.

◆ process()

template<typename SampleType >
void juce::dsp::LinkwitzRileyFilter< SampleType >::process ( const ProcessContext context)
noexcept

Processes the input and output samples supplied in the processing context.

Definition at line 82 of file juce_LinkwitzRileyFilter.h.

◆ processSample() [1/2]

template<typename SampleType >
SampleType juce::dsp::LinkwitzRileyFilter< SampleType >::processSample ( int  channel,
SampleType  inputValue 
)

Performs the filter operation on a single sample at a time.

Definition at line 87 of file juce_LinkwitzRileyFilter.cpp.

◆ processSample() [2/2]

template<typename SampleType >
void juce::dsp::LinkwitzRileyFilter< SampleType >::processSample ( int  channel,
SampleType  inputValue,
SampleType &  outputLow,
SampleType &  outputHigh 
)

Performs the filter operation on a single sample at a time, and returns both the low-pass and the high-pass outputs of the TPT structure.

Definition at line 112 of file juce_LinkwitzRileyFilter.cpp.

◆ reset()

template<typename SampleType >
void juce::dsp::LinkwitzRileyFilter< SampleType >::reset ( )

Resets the internal state variables of the filter.

Definition at line 71 of file juce_LinkwitzRileyFilter.cpp.

◆ setCutoffFrequency()

template<typename SampleType >
void juce::dsp::LinkwitzRileyFilter< SampleType >::setCutoffFrequency ( SampleType  newCutoffFrequencyHz)

Sets the cutoff frequency of the filter in Hz.

Definition at line 44 of file juce_LinkwitzRileyFilter.cpp.

◆ setType()

template<typename SampleType >
void juce::dsp::LinkwitzRileyFilter< SampleType >::setType ( Type  newType)

Sets the filter type.

Definition at line 38 of file juce_LinkwitzRileyFilter.cpp.

◆ snapToZero()

template<typename SampleType >
void juce::dsp::LinkwitzRileyFilter< SampleType >::snapToZero ( )
noexcept

Ensure that the state variables are rounded to zero if the state variables are denormals.

This is only needed if you are doing sample by sample processing.

Definition at line 78 of file juce_LinkwitzRileyFilter.cpp.


The documentation for this class was generated from the following files: