Overview
2nd order cascaded IIR filter, high precision
Discussion
Second order cascaded 5 multiply recursive filter with algorithm precision uses 24x24 with 56-bit accumulator. The module is designed to operate on multiple channels and applies the same coefficients across all channels. The state array is allocated to contain 6*numStages*numChannels values. The frequency response of the module is determined by the values of the 5 coefficients, and the coefficients come directly from the MATLAB second order representation. The leading a0 coefficient is not supplied and is assumed to equal 1.0. The module implements the difference equation:
$y[n]=b_0x[n]+b_1x[n-1]+b_2x[n-2]-a_1y[n-1]-a_2y[n-2].$
Type Definition
Code Block |
---|
typedef struct _ModuleBiquadCascadeHPFract32 { ModuleInstanceDescriptor instance; // Common Audio Weaver module instance structure INT32 numStages; // Number of cascaded stages of the second order filter. INT32 bShift; // Number of bits to shift of Numerator coefficients INT32 aShift; // Number of bits to shift of Denominator coefficients FLOAT32* coeffs; // coefficients fract32* coeffsFract32; // coefficients in Fract32 fract32* state; // State variables. 6 per channel. } ModuleBiquadCascadeHPFract32Class; |
Variables
Properties
Name | Type | Usage | isHidden | Default value | Range | Units |
numStages | int | const | 0 | 1 | 1:1:32 | |
bShift | int | parameter | 1 | 1 | Unrestricted | |
aShift | int | parameter | 1 | 1 | Unrestricted | |
coeffs | float* | parameter | 0 | [5 x 1] | Unrestricted | |
coeffsFract32 | fract32* | derived | 0 | [5 x 1] | Unrestricted | |
state | fract32* | state | 1 | [6 x 1] | Unrestricted |
Pins
Input Pins
Name: in
Description: audio input
...
Sample rate range: Unrestricted
Complex support: Real
Output Pins
Name: out
Description: audio output
Data type: fract32
MATLAB Usage
File Name: biquad_cascadeHP_fract32_module.m
...