FIR Lowpass Filter Example

group FIRLPF

Refer riscv_fir_example_f32.c

Description:

Removes high frequency signal components from the input using an FIR lowpass filter. The example demonstrates how to configure an FIR filter and then pass data through it in a block-by-block fashion. ../../../_images/FIRLPF_signalflow.png

Algorithm:

The input signal is a sum of two sine waves: 1 kHz and 15 kHz. This is processed by an FIR lowpass filter with cutoff frequency 6 kHz. The lowpass filter eliminates the 15 kHz signal leaving only the 1 kHz sine wave at the output.

The lowpass filter was designed using MATLAB with a sample rate of 48 kHz and a length of 29 points. The MATLAB code to generate the filter coefficients is shown below: The first argument is the “order” of the filter and is always one less than the desired length. The second argument is the normalized cutoff frequency. This is in the range 0 (DC) to 1.0 (Nyquist). A 6 kHz cutoff with a Nyquist frequency of 24 kHz lies at a normalized frequency of 6/24 = 0.25. The NMSIS FIR filter function requires the coefficients to be in time reversed order. The resulting filter coefficients and are shown below. Note that the filter is symmetric (a property of linear phase FIR filters) and the point of symmetry is sample 14. Thus the filter will have a delay of 14 samples for all frequencies.

../../../_images/FIRLPF_coeffs.png

The frequency response of the filter is shown next. The passband gain of the filter is 1.0 and it reaches 0.5 at the cutoff frequency 6 kHz.

../../../_images/FIRLPF_response.png

The input signal is shown below. The left hand side shows the signal in the time domain while the right hand side is a frequency domain representation. The two sine wave components can be clearly seen.

../../../_images/FIRLPF_input.png

The output of the filter is shown below. The 15 kHz component has been eliminated.

../../../_images/FIRLPF_output.png

Variables Description:

  • testInput_f32_1kHz_15kHz points to the input data

  • refOutput points to the reference output data

  • testOutput points to the test output data

  • firStateF32 points to state buffer

  • firCoeffs32 points to coefficient buffer

  • blockSize number of samples processed at a time

  • numBlocks number of frames

NMSIS DSP Software Library Functions Used:

  • riscv_fir_init_f32()

  • riscv_fir_f32()