/
(8.D.2.8) Biquad

(8.D.2.8) Biquad

Overview

2nd order IIR filter

Discussion

Standard second order 5 multiply recursive filter. The module is designed to operate on multiple channels and applies the same coefficients across all channels. The state array is allocated to contain 2*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 order of the coefficients must be [b0 b1 b2 a1 a2]. 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

typedef struct _ModuleBiquad { ModuleInstanceDescriptor instance; // Common Audio Weaver module instance structure FLOAT32 b0; // First numerator coefficient. FLOAT32 b1; // Second numerator coefficient. FLOAT32 b2; // Third numerator coefficient. FLOAT32 a1; // Second denominator coefficient. FLOAT32 a2; // Third denominator coefficient. FLOAT32* state; // State variables. 2 per channel. } ModuleBiquadClass;

Variables

Properties

Name

Type

Usage

isHidden

Default value

Range

Units

hardware_specific_struct_pointer

void *

state

1

 

Unrestricted

hardware_specific_struct_pointer

Pins

Input Pins

Name: in

Description: Complex input

Data type: float

Channel range: Unrestricted

Block size range: 3, 5, 9, 17, 33, 65, 129, 257, 513, 1025, 2049, 4097, 8193

Sample rate range: Unrestricted

Complex support: Complex

Output Pins

Name: out

Description: Real input

Data type: float

Scratch Pins

Channel count: 1

Block size: 4

Sample rate: 48000

MATLAB Usage

File Name: ifft_module.m

M=ifft_module(NAME) Computes the inverse FFT of a real time domain sequence. The input block is complex valued with a blockSize of N/2+1. The output is real data of length N. The module supports multichannel signals. Arguments: NAME - name of the module.