# Semester Project

Architectural exploration of low-pass FIR filters using MATLAB HDL Coder

Student: Nikolaos Stylianou

AEM: 2917

Course: ECE 494 - Processor Design



June 24, 2023

## Contents

# Introduction Filter Creation Filter Synthesis 3.1 Importing MATLAB HDL files 3.2 Synthesis in Vivado Filter Comparison 4.1 Minimum Order filter 4.2 20 Order filter 4.3 30 Order filter

# 1 Introduction

a type of digital filter used in signal processing to attenuate or remove high-frequency components from a signal, allowing only low-frequency com-3 ponents to pass through. FIR filters are charac-3 terized by their impulse response, which is a finite 3 duration sequence of coefficients. The basic op-3 eration of a low-pass FIR filter involves convolving the input signal with the impulse response 3 of the filter. The filter coefficients determine the 3 filter's frequency response, and specifically in a low-pass filter, they emphasize the passage of lowfrequency signals and suppress higher frequencies The design of a low-pass FIR filter involves determining the appropriate filter order (length) and selecting the filter coefficients. The filter order determines the length of the filter's impulse response and affects the sharpness of the filter's frequency cutoff. Higher filter orders generally result in steeper roll-off characteristics but require more computational resources.

A low-pass FIR (Finite Impulse Response) filter is

For this project, I will be focused in exploring



Figure 1: FIR magnitude response

the architecture of an FIR filter with the following characteristics:

• Sampling frequency: 46 kHz

• Pass frequency: 8 kHz

• Stop frequency: 9.6 kHz

• Number of coefficients:

- Minimum coefficients possible

- 20 coefficients

- 30 coefficients

### • Arithmetic:

- Single precision floating point
- Fixed point 24 bits
- Fixed point 16 bits
- Fixed point 8 bits

### • Optimizations:

- 1 stage multiplier pipelining
- 2 stage multiplier pipelining
- Multiplier-less using CSD
- Distributed Arithmetic

The implemented filter has a magnitude response as figure 1 shows.

# 2 Filter Creation

Before creating any HDL code, the filter has to be normally implemented in MATLAB. Using designfilt command, every parameter of the filter is filled with the help of GUI. We call this function 3 times, one for each different order of filter, thus creating 3 different FIR filters. Using



Figure 2: MATLAB's design assist tool for creating lowpass FIR filters

fvtool, all three filters can be compared and be checked for compliance.

For HDL Coder to work, all filters must be designed by fdesign.lowpass() and design() functions, thus all filters created above must be re-created. The first function creates the specification for each filter containing useful information such as passband/stopband frequency, sample rate, etc. In order to actually create the filter, design() function has to be called and it returns dsp.FIRFilter data type, meaning that the wanted filter is successfully created. Note that, we make use of two specific toolboxes provided by Mathworks, called DSP System Toolbox and DSP HDL Toolbox that provide those "easy" methods of creating filters alongside with optimizations like pipelining, CSD and others needed for this project.

After each filter is created, fdhdltool has to be called with filter specifications and numeric type needed as arguments. Every aspect of the generated filter can be tuned from there such configuring architectures, multiplier pipelining, test bench generator and more. This task has to be executed for each implemented filter.



Figure 3: MATLAB's tool for creating HDL filters.

# 3 Filter Synthesis

Once creating every filter with its own configuration, each HDL file has to be synthesized and/or implemented in order to compare each architecture. For this process, Xilinx Vivado seems to be the best option to use as other great EDA tools like Synopsys and Cadence suites weren't available. Since I'm using Vivado, I should as well target an FPGA that might have access such as the Zedboard. Zedboard isn't a very big FPGA in terms of memory size, but, hopefully, it might be able to implement some filters at the end.

# 3.1 Importing MATLAB HDL files

In Vivado, a new project is created for each filter architecture. Files are imported using the standard GUI procedure while also adding constraints for the target device mentioned above. MATLAB produces source HDL and test-bench for each filter created as well as some .do files that tell Xilinx's compiler what to do.

# 3.2 Synthesis in Vivado

After importing all necessary files into Vivado, we must assure the functionality of the exported circuit. First we set the target device, which as said before is the *Zedboard*, the target clock

 $(\approx 10 \text{ ns})$  and then simulation starts with the included simulator, vsim. Also, MATLAB streamlines this process by adding some specific tests inside testbenches, to lighten designer's workload. After functionality is ensured, synthesis takes place where utilization of LUTs ( $Look\ Up\ Tables$ ), flip-flops and of other critical components is measured. So, this will be the way of comparing all architectures.

In order to get more accurate results, constraints for the target chip must be set-up. Those include mostly timing constraints that help Vivado predict the circuit's power consumption and whether it passes/fails the timing checks.

Finally, each project gets implemented to check if the systems meets the timing criteria introduced in the step before. After implementation is achieved, we start to compare each result and from an opinion about each architecture presented.

# 4 Filter Comparison

### 4.1 Minimum Order filter

Beginning with the minimum order one using floating point precision (32 bits), we can observe that the circuit created cannot fit inside the target FPGA.

### 4.2 20 Order filter

### 4.3 30 Order filter