



# **Parametric IIR Filtering on an FPGA**

Department of Electrical and Computer Engineering Signal Processing Research laboratory

David Walker-Howell and Ashkan Ashrafi

# **Table of Contents**

| Introduction             | 3   |
|--------------------------|-----|
| Requirements             | . 3 |
| Theory                   | 3   |
| Design                   | . 4 |
| Hardware Setup           | 6   |
| Implementation           | 7   |
| Graphical User Interface | 13  |
| Testing and Verification | 15  |
| References               | 19  |

# Introduction

This paper presents a tutorial for a real-time parametric IIR filter implementation on the Xilinx Virtex-5 FPGA ML506 Evaluation Platform. The FPGA implements a biquad IIR filter architecture with the ability to dynamically load new filter coefficients via serial UART communication. A host PC running a Python-based graphical user interface (GUI) allows real-time control of the filter's parameters such as gain, center-frequency, and bandwidth. In this tutorial, the peaking/notch type filter is used as demonstration for its practical application in audio equalization. However, this design can be generalized for other filter types like lowpass, highpass, bandpass, etc.

# Requirements

The requirements specified are necessary to be able to follow this tutorial step-by-step. However, most of the software components are generalized and modular, and thus could be extended for use with other hardware platforms.

#### Hardware Requirements

- Xilinx ML506 Evaluation Platform (features Virtex-5 FPGA).
- Xilinx Platform Cable USB II
- Digilent Pmod DA2 digital-to-analog converter (DAC).
- Digilent Pmod AD1 analog-to-digital converter (ADC).
- USB to 3.3V UART breakout board.
- Waveform function generator.
- Oscilloscope (2+ channels).

#### Software Requirements

- ISE Design Suite 14.7 (Version used in the making of this tutorial. Other versions may be possible to use.)
- Python 3.7.1 (with the following library dependencies installed).
  - o Numpy
  - PyQt5
  - o pyqtgraph
  - PySerial

## Theory

IIR filters are advantageous for digital filtering applications requiring variety of frequency response selectability. In general, the filters magnitude response can be met more efficiently compared to the Finite Impulse Response (FIR) filters [1]. Due to the IIR filters design process, which derives from continuous-time filter designs, the generation of filter coefficients can be computed using closed form equations. This leads to fast, non-iterative computer programs for generating the filter coefficients, which is desired for adjustments of the frequency response in real-time.

A useful application for a parametrically adjustable IIR filter is an audio equalizer. Audio equalizers, often used in music applications, boost or attenuate specific frequency bands. These equalizers require filter banks of parametrically adjustable filters to be able to control gain, center frequency, and bandwidth. The filters in an equalizer have a peaking or notch type filter form to allow for unity gain passing of the input signal at the frequency bands not being adjusted **Figure 1**. The architecture and hardware implementation of the parametric IIR filter presented in this tutorial demonstrates the concepts of a digital hardware-based equalizer.



Figure 1: Example of parametric equalizer frequency response using peaking/notch filter.

The biquad filter is used in this project because it is a second order filter that allows for a quality magnitude response with only two poles and two zeros. A basic form of the filter, called Direct Form I, is given as

Frequency Response  $H(z) = \frac{b_0 + b_1 z^{-1} + b_2 z^{-2}}{1 + a_1 z^{-1} + a_2 z^{-2}}$ 

Impulse Response  $y[k] = b_0 x[k] + b_1 x[k-1] + b_2 x[k-2] - a_1 y[k-1] - a_2 y[k-2]$ 

The five coefficients are computed using a set of closed form equations which are given in [2]. Note, depending on the type of filter used, there are different sets of closed form equations that can be derived.

Since the IIR filter is implemented in the digital hardware of the FPGA, the coefficients cannot be infinite precision floating-point. The IIR filter implementation used in this project requires the coefficients to be fixed-point two's complement binary. The conversion from floating-point to fixed-point introduces round-off error that can make the filter response significantly differ from the original design or even cause the filter to become unstable [3]. As an example, if the coefficients of the poles are too close to the unit circle, then the conversion to fixed-point might cause the poles to go outside the unit circle, resulting in an unstable filter. There are a few ways to help the errors be less significant.

- 1. Use as many bits as possible for fixed-point representation.
- 2. Make the number of fractional bits only 1-2 less than the total number of bits. For example, if 16-bits are used for representation, make 14-bits the fractional part.
- 3. Normalize the coefficients and signals for filtering to mitigate overflow.

In this project, the coefficients and signals are represented with a total width of 16-bits and a fractional width of 14-bits.

### System Design

The architecture of the FPGA implementation is broken up into multiple modules. See Figure 2.



Figure 2: System block diagram.

First, the desired filter response is designed via the Python GUI on the host PC. The filter coefficients are generated and serialized to be sent to the FPGA via UART serial communication. The Verilog UART Receiver Module reads in 10-bit (1 start bit, 8 data bits, 1 stop bit) data packets and extracts the data. This data is then sent to the Data Unpack Module to check which coefficient data the individual bytes correspond to. **Figure 3** shows what a valid coefficient data packet looks like.

|        | SE     | RIALIZED | COEFFICIENT DATA                        | PACKET        |        |
|--------|--------|----------|-----------------------------------------|---------------|--------|
| START1 | START2 | FILTER # | COEFFICIENTS<br>a 1, a 2, b 0, b 1, b 2 | END<br><0XFA> | BUFFER |
| 1 BYTE | 1 BYTE | 1 BYTE   | 10 BYTES                                | 1 BYTE        | 2 BYTE |
| •      |        |          | 16 BYTES                                |               |        |

Figure 3: Coefficient data packet that is unpacked and validated by the Data Unpack Module.

Once the coefficients are successfully unpacked, the coefficients are moved into a simple RAM block in the Coefficient Controller Module. The Coefficient Controller Module is responsible for timing when to change the coefficients of filter to ensure the change in frequency response is fast and stable. Coefficients are changed in the filter when the filter module has finished its accumulation step and before the next input is sampled. Finally, the Biquad IIR Filter Module samples the inputs from the ADC at every sample clock, performs a multiplication and accumulation sequence, then sends the output to the DAC. **Figure 4** shows the clocking of the IIR filter computations with respect to the sample clock and FPGA's system clock.



Figure 4: Verilog IIR filtering computation stages.

# Hardware Setup

#### **USB UART Serial Breakout**

UART communication is used to transmit the filter coefficients from the host PC to the FPGA. A USB to UART converter breaks out the USB data lines to I/O UART TX/RX pins that can be connected to the FPGA via GPIO. In this project, the SparkFun USB UART Serial Breakout - CY7C65213 [4] was used. Any USB to UART breakout board will work fine for this project. Make sure the logic voltages match; for the ML506 Evaluation Board, the single-ended GPIO voltage logic is 3.3V.

- 1. Connect the host PC to the converter with an appropriate USB cable.
- 2. Connect the ground pin on the converter to the ground on the FPGA.
- 3. Connect the transmit pin (TX) on the converters to pin number 2 (HDR1\_2) on the FPGA's singledended GPIO.



Figure 5: USB to UART breakout board connect to the Virtex-5 single-ended GPIO.

| FPGA Pin Name | USB/UART Converter Pin Name |
|---------------|-----------------------------|
| HDR1_2        | TX                          |
| GND           | GND                         |

Table 1: Virtex-5 FPGA GPIO connection with the USB to UART breakout board.

### **Digilent Pmod DA2 DAC**

The Digilent Pmod DA2 12-bit, 2 channel DAC [5] converts the digital output signal from the IIR filter to an analog signal that can be observed with an oscilloscope. The Pmod DA2 communicates with the FPGA logic through the single-ended GPIO pins. The communication protocol is similar to SPI, where the 12-bit resolution digital signal is synchronously sent from the FPGA to the DAC.



Figure 6: The Digilent Pmod DA2 12-bit, 2 channel digital-to-analog converter. Source: [5].

**Figure 7** shows the GPIO to DAC connections on the FPGA. The right-most column of pins is the single-ended GPIO pins. The middle column are all ground pins.

- 1. Connect the DA2 pins (1, 2, 3, 4) to FPGA'S GPIO pins (4, 6, 8, 10) respectively.
- 2. Connect the DA2 VCC pin to a 3.3V power pin on the FPGA.
- 3. Connect the DA2 GND pin to ground on the FPGA.



Figure 7: The highlighted GPIO pins to connect the Digilent Pmod DA2.

| FPGA Pin Name | Pmod DA2 Pin Name | Pmod DA2 Pin Number |
|---------------|-------------------|---------------------|
| HDR1_4        | ~SYNC             | 1                   |
| HDR1_6        | DINA              | 2                   |
| HDR1_8        | DINB              | 3                   |
| HDR1_10       | SCLK              | 4                   |
| GND           | GND               | 5                   |
| VCC3V3        | VCC               | 6                   |

Table 2: Virtex-5 FPGA GPIO pin to PMOD DA2 pin connections.

The connection order for the DAC is shown in Table 2. Male-to-female jumper wires are suggested.

#### **Digilent Pmod AD1 ADC**

The Digilent Pmod AD1 12-bit, 2 channel ADC [6] also provides an SPI-like communication protocol with up to 1MSa of 12-bit conversion. It's operation and connection type are similar to the Pmod DA2 DAC.

- 1. Connect the AD1 pins (1, 2, 3, 4) to FPGA'S GPIO pins (12, 14, 16, 18) respectively.
- 2. Connect the AD1 VCC pin to a 3.3V power pin on the FPGA.
- 3. Connect the AD1 GND pin to ground on the FPGA.



*Figure 8*: The highlighted GPIO pins to connect the Digilent Pmod AD1.

| Pmod AD1 Pin Name | Pmod AD1 Pin Number          |
|-------------------|------------------------------|
| CS                | 1                            |
| D0                | 2                            |
| D1                | 3                            |
| SCK               | 4                            |
| GND               | 5                            |
| VCC               | 6                            |
|                   | CS<br>D0<br>D1<br>SCK<br>GND |

Table 3: Virtex-5 FPGA GPIO pin to PMOD DA2 pin connections.

The connection order for the ADC is shown in Table 3. Male-to-female jumper wires are suggested.

### Implementation

To implement the digital system on the FPGA, Xilinx ISE Design Suite 14.7 is used.

1. In a desired file location to store the project files. Open Xilinx ISE Design Suite. Under **File**, click **New Project**. The project wizard in **Figure 9** will appear. Give the project a name and save it in any desired location. Make sure the **Top-level source type** is HDL. Finally click **Next**.

| lew Project Wizard                      | 1                                           |   |   |
|-----------------------------------------|---------------------------------------------|---|---|
| eate New Project<br>Specify project loc | ation and type.                             |   |   |
| Enter a name, location                  | ns, and comment for the project             |   |   |
| Name:                                   | parametric_IIR_filter                       |   |   |
| Location:                               | C:\Users\User\Desktop\parametric_IIR_filter |   |   |
| Working Directory:                      | C:\Users\User\Desktop\parametric_IIR_filter |   |   |
| Description:                            |                                             |   |   |
|                                         |                                             |   |   |
|                                         |                                             |   |   |
|                                         |                                             |   |   |
|                                         |                                             |   |   |
|                                         |                                             |   |   |
|                                         |                                             |   |   |
|                                         |                                             |   |   |
| Colort the home of ten                  | -level source for the project               |   |   |
|                                         |                                             |   |   |
| Top-level source typ                    | e:                                          |   |   |
| HDL                                     |                                             | ~ | ' |
|                                         |                                             |   |   |
|                                         |                                             |   |   |

Figure 9: New Project Wizard.

Next, the project settings, shown in Figure 10 will be set to ensure the Xilinx software configures to the correct FPGA hardware. In the Evaluation Development Board dropdown select Virtex 5 ML506 Evaluation Platform; this will automatically fill-in the correct properties of Product Category, Family, Device, Package, and Speed. The rest of the settings should match Figure 10. Click Next, then Finish.

| elect the device and design flow for the proj | ect                                |   |
|-----------------------------------------------|------------------------------------|---|
| Property Name                                 | Value                              |   |
| Evaluation Development Board                  | Virtex 5 ML506 Evaluation Platform | ~ |
| Product Category                              | All                                | ~ |
| Family                                        | Virtex5                            | ~ |
| Device                                        | XC5VSX50T                          | ~ |
| Package                                       | FF1136                             | ~ |
| Speed                                         | -1                                 | ~ |
| Top-Level Source Type                         | HDL                                | ~ |
| Synthesis Tool                                | XST (VHDL/Verilog)                 | ~ |
| Simulator                                     | Modelsim-SE VHDL                   | ~ |
| Preferred Language                            | VHDL                               | ~ |
| Property Specification in Project File        | Store all values                   | ~ |
| Manual Compile Order                          |                                    |   |
| /HDL Source Analysis Standard                 | VHDL-93                            | ~ |
| Enable Message Filtering                      |                                    |   |

Figure 10: Project property settings.

3. The ZIP folder **Parametric\_IIR\_Filter\_FPGA.zip** contains the Verilog and Constraints files for this project. Unzip this folder to a suitable location. As shown in **Figure 11**, select the **Project** tab, then click **Add Copy of Source** to add all the files to the project. Select all the unzipped files shown in **Figure 12**. Click **Open**, then **Next**.

| Desig | n 🔁 🗐 👘                                                                                                               | Mew Source Add Source                                                       | ₽ ₽ Ø Ø ₽ <b>@</b><br>+□ ₽>                   |  |  |  |
|-------|-----------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|-----------------------------------------------|--|--|--|
| F     | View: 🖲 🄯 In                                                                                                          | Add Copy of Source                                                          |                                               |  |  |  |
|       | Hierarchy                                                                                                             | New VHDL Library<br>Manual Compile Order<br>Import Custom Compile File List |                                               |  |  |  |
| 9     | The vie<br>toolbar<br>Files, a                                                                                        | Disable Hierarchy Reparsing<br>Force Hierarchy Reparse                      | to the project using the by using the Design, |  |  |  |
| 2     | Use:                                                                                                                  | Cleanup Project Files                                                       |                                               |  |  |  |
|       |                                                                                                                       | Archive<br>Generate Tcl Script                                              | ect.                                          |  |  |  |
|       |                                                                                                                       | Design Goals & Strategies                                                   | o the project directory                       |  |  |  |
|       | and<br>and<br>and and<br>and and<br>and and<br>and and<br>and<br>and<br>and<br>and<br>and<br>and<br>and<br>and<br>and | Design Summary/Reports                                                      |                                               |  |  |  |

Figure 11: Add copy of source files to project.

| Date modified      | Туре                                                                                                                                                                 | Size                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10/20/2019 8:18 PM | Verilog File                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                            |
| 4/11/2020 6:01 PM  | Verilog File                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                            |
| 4/18/2020 6:38 PM  | Verilog File                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                            |
| 11/3/2019 2:27 PM  | Verilog File                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                            |
| 4/14/2020 2:21 PM  | Verilog File                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                            |
| 4/9/2020 10:48 AM  | Verilog File                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                            |
| 4/11/2020 5:57 PM  | Verilog File                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                            |
| 4/22/2020 9:51 AM  | Verilog File                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                            |
| 4/20/2020 12:02 PM | UCF File                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                            |
| 4/11/2020 6:08 PM  | Verilog File                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                            |
|                    |                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                            |
|                    |                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                            |
|                    | 4/11/2020 6:01 PM<br>4/18/2020 6:38 PM<br>11/3/2019 2:27 PM<br>4/14/2020 2:21 PM<br>4/9/2020 10:48 AM<br>4/11/2020 5:57 PM<br>4/22/2020 9:51 AM<br>4/22/2020 9:51 AM | 4/11/2020 6:01 PM         Verilog File           4/18/2020 6:38 PM         Verilog File           11/3/2019 2:27 PM         Verilog File           4/14/2020 2:21 PM         Verilog File           4/9/2020 10:48 AM         Verilog File           4/11/2020 5:57 PM         Verilog File           4/22/2020 9:51 AM         Verilog File           4/20/2020 12:02 PM         UCF File |

Figure 12: All the necessary source files for implementation.

4. Make sure the module **top\_level.v** is set as the top level module. A top level module is signified by 3 squares with one highlighted green and have all of the other modules nested underneath it. See **Figure 13**.

| - 「うら ×00% % 00× 50  *                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1          | BBI                                                                  | * 🗟 💫 🗟 🗄 🖬 🖻 🥕 🛠 🕨 🗶 🛠 💡                                                                                                                                                                                                                           |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|----------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| esign ↔□5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ×          | 68                                                                   |                                                                                                                                                                                                                                                     |
| 🕴 View: 💿 🄯 Implementation 🔿 M Simulation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | <b>b</b> Ξ | 69                                                                   | //UART RECEIVE MO                                                                                                                                                                                                                                   |
| Hierarchy                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |            | 70                                                                   | parameter RECEIVER_CLK_COUNTS = 88, REC                                                                                                                                                                                                             |
| a parametric IIR filter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |            | 71                                                                   | wire RECEIVER_CLK;                                                                                                                                                                                                                                  |
| arametric_lik_filter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 10         | 72                                                                   | wire RXC;                                                                                                                                                                                                                                           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1          | 73                                                                   | wire [7:0] UDRRX;                                                                                                                                                                                                                                   |
| receiver clk - clock divider (clock divider                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |            | 74                                                                   | //Instantiate the clock divider to divi                                                                                                                                                                                                             |
| rx - receive (receive.v)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | der.       | 75                                                                   | clock_divider #(.COUNTS(RECEIVER_CLK_CO                                                                                                                                                                                                             |
| 2 w necestary (unpack_bytes (unpack_bytes)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | .v) A      | 76                                                                   | (.CLK_IN(CLK_27MHZ_FPGA)                                                                                                                                                                                                                            |
| 2 coeff_controller - coefficient_controlle                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | elce .     | 77                                                                   | //Instantiate the receive RX module                                                                                                                                                                                                                 |
| a sample_clock - clock_divider (clock_div                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |            | 78<br>79                                                             | receive rx (.CLK(RECEIVER CLK), .RX IN(                                                                                                                                                                                                             |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |            | 80                                                                   | receive ix (.CLK(RECEIVER_CLK), .RA_IN(                                                                                                                                                                                                             |
| Filter_1 - IIR_filter_biquad_df1 (IIR_filter_<br>da2_pmod - digilent_PMOD_DA2 (digil                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |            | 81                                                                   | assign GPIO_LED_1 = (UDRRX == 8'h00) ?                                                                                                                                                                                                              |
| ad1 - digilent PMOD AD1 (digilent PM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 100 /101   |                                                                      | assign orio_bbb_i - (obkiak - o noo) :                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |            | 82                                                                   | //                                                                                                                                                                                                                                                  |
| clk_1hz - clock_divider (clock_divider.v                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |            | 82                                                                   | //                                                                                                                                                                                                                                                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |            | 83                                                                   | //DAT                                                                                                                                                                                                                                               |
| clk_1hz - clock_divider (clock_divider.v                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |            |                                                                      |                                                                                                                                                                                                                                                     |
| clk_1hz - clock_divider (clock_divider.v                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |            | 83<br>84                                                             | //DAT.<br>//wire [7:0] filter_num;<br>wire [15:0] coeff to controller;                                                                                                                                                                              |
| V clk_1hz - clock_divider (clock_divider.v                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ) ()       | 83<br>84<br>85                                                       | <pre>//wire [7:0] filter_num;</pre>                                                                                                                                                                                                                 |
| clk_1hz - clock_divider (clock_divider.v                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |            | 83<br>84<br>85<br>86                                                 | <pre>//wire [7:0] filter_num;<br/>wire [15:0] coeff_to_controller;</pre>                                                                                                                                                                            |
| V clk_lhz-clock_divider(clock_divider.v     V clock_divider.v     V clock_divider.v | ) ()       | 83<br>84<br>85<br>86<br>87                                           | <pre>//wire [7:0] filter_num;<br/>wire [15:0] coeff_to_controller;<br/>wire [2:0] coeff_addr_to_controller;<br/>wire WRITE_EN;</pre>                                                                                                                |
| <ul> <li>k, The - clock divider (clock_divider.v</li> <li>top_level_constraints.ucf</li> <li>No Processes Running</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ) ()       | 83<br>84<br>85<br>86<br>87<br>88                                     | <pre>//wire [7:0] filter_num;<br/>wire [15:0] coeff_to_controller;<br/>wire [2:0] coeff_addr_to_controller;<br/>wire WRITE_EN;<br/>//Instantiate the unpack bytes module.</pre>                                                                     |
| V clk_lhz-clock_divider(clock_divider.v     V clock_divider.v     V clock_divider.v | ) ()       | 83<br>84<br>85<br>86<br>87<br>88<br>89                               | <pre>wire [15:0] coeff_to_controller;<br/>wire [2:0] coeff_addr_to_controller;<br/>wire WRITE_EN;<br/>//Instantiate the unpack bytes module.<br/>unpack_bytes #(.NUM_FILTERS(1)) unpack</pre>                                                       |
| <ul> <li>k, The - clock divider (clock_divider.v</li> <li>top_level_constraints.ucf</li> <li>No Processes Running</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ) ()       | 83<br>84<br>85<br>86<br>87<br>88<br>89<br>90<br>91<br>92             | <pre>//wire [7:0] filter_num;<br/>wire [15:0] coeff_to_controller;<br/>wire [2:0] coeff_addr_to_controller;<br/>wire WRITE_EN;<br/>//Instantiate the unpack bytes module.<br/>unpack_bytes \$(.NUM_FILTERS(1)) unpack<br/>coeff_add(coeff_a)</pre>  |
| Vorgen and the second sec | ) ()       | 83<br>84<br>85<br>86<br>87<br>88<br>89<br>90<br>91<br>92<br>93       | <pre>//wire [7:0] filter_num;<br/>wire [15:0] coeff_to_controller;<br/>wire [2:0] coeff_addr_to_controller;<br/>wire WRITE_EN;<br/>//Instantiate the unpack bytes module.</pre>                                                                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ) ()       | 83<br>84<br>85<br>86<br>87<br>88<br>89<br>90<br>91<br>92<br>93<br>94 | <pre>//wire [7:0] filter_num;<br/>wire [15:0] coeff_to_controller;<br/>wire [2:0] coeff_addr_to_controller;<br/>wire WRITE_EN;<br/>//Instantiate the unpack bytes module.<br/>unpack_bytes \$(.NUM_FILTERS(1)) unpack<br/>coeff_addd(coeff_a)</pre> |
| <ul> <li>V clk, Thz - clock, divider (clock_divider.v</li> <li>top_level_constraints.ucf</li> <li>No Processes Running</li> <li>Processes: top_level</li> <li>Design Summary/Reports</li> <li>Design Summary/Reports</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ) ()       | 83<br>84<br>85<br>86<br>87<br>88<br>89<br>90<br>91<br>92<br>93       | <pre>//wire [7:0] filter_num;<br/>wire [15:0] coeff_to_controller;<br/>wire [2:0] coeff_addr_to_controller;<br/>wire WRITE_EN;<br/>//Instantiate the unpack bytes module<br/>unpack_bytes \$(.NUM_FILTERS(1)) unpac<br/>.coeff_addr(coeff</pre>     |

Figure 13: How to project looks after importing source files.

 Lastly, the design is synthesized for the FPGA hardware and a programming file (bitstream) is generated to load the design onto the FPGA. On the bottom-left hand-side in the **Processes** task bar double-click **Synthesize – XST**. It will be noticed that there are numerous warning messages after the synthesis completes; this is okay and should not result in any problems. Next, double-click **Implement Design**. Finally, after the implantation stage is successful, double-click **Generate Programming File**. The result should look similar to **Figure 14**.



Figure 14: Post successful Synthesis, Implementation, and Bitstream.

6. Connect the Xilinx Platform Cable USB II to the FPGA and PC. This device is needed to program the bitstream from the PC to the FPGA.



Figure 15: Xilinx Platform Cable USB II connected.

 In Xilinx ISE, select i<u>MPACT</u> from the Tool dropdown. This will open the i<u>MP</u>ACT editor, the tool to load the bitstream to the FPGA. See Figure 16. In the i<u>MP</u>ACT tool, double-click Boundary Scan, follow instructions to Right click to Add Device, and click Initialize Chain. See Figure 17.



Figure 16: Opening ISE i<u>M</u>PACT.

|                                                                             | n)        |      |                                                                                                                        |                            |                    | _ |      | ×   |
|-----------------------------------------------------------------------------|-----------|------|------------------------------------------------------------------------------------------------------------------------|----------------------------|--------------------|---|------|-----|
| ISE iMPACT (P.20131013) - (Boundary Sca<br>Elle Edit View Operations Qutput |           | Helo |                                                                                                                        |                            |                    |   | -    |     |
|                                                                             |           | Tech |                                                                                                                        |                            |                    |   |      |     |
|                                                                             |           |      |                                                                                                                        |                            |                    |   |      | -   |
| Create PROM File Format.      WebTas Data      WebTas Data                  |           |      | Add Xilinx Device<br>Add Yon Xilinx Device<br>Indialize Class<br>Sable Auto Connect<br>Cable Setup<br>Outrat Elis Tang | Ctrl+D<br>Ctrl+K<br>Ctrl+I | lottake 77AG chain |   |      |     |
| vantor operators are                                                        |           |      | Qutput File Type                                                                                                       | ,                          |                    |   |      |     |
|                                                                             | <b>\$</b> | Bo   | undary Scan                                                                                                            |                            |                    |   |      |     |
|                                                                             |           |      |                                                                                                                        |                            |                    |   |      |     |
| tonsole                                                                     |           |      |                                                                                                                        |                            |                    |   | ** 0 | 1   |
| lonsole                                                                     |           |      |                                                                                                                        |                            |                    |   | ** 0 | 3 6 |

Figure 17: Initialize chain to program FPGA.

8. The last step is to set the Generated Programming File to be the configuration file for the FPGA. Make sure the targeted FPGA device in the tool chain, labeled xc5vsx50t, is highlighted green as shown in Figure 18. Right click on the device, then choose Assign New Configuration File. From the file explore that pops-up, navigate to the main ISE project folder and select top\_level.bit. See Figure 19.

| 🕞 ISE iMPACT (P.20131013) - [Boundary Scan]                                   |                   |                  |                     |                  |                     | - 🗆 ×                                              |
|-------------------------------------------------------------------------------|-------------------|------------------|---------------------|------------------|---------------------|----------------------------------------------------|
| Eile Edit View Ogerations Qutput                                              | Debug Window Help |                  |                     |                  |                     | _ @ ×                                              |
| D ≥ E × 0 0 × 11 11                                                           | ¥ II 🚡 🗆 🔑 K?     |                  |                     |                  |                     |                                                    |
| MPACT Flows ↔ □ 중 ×                                                           |                   |                  |                     |                  |                     |                                                    |
| Boundary Scan     SystemACE     Create PROM File (PROM File Format            | THE               | Emar             | Exter               | Frank            | 200900<br>E 1000    |                                                    |
| 🗄 - 📄 WebTalk Data                                                            | TDI               |                  |                     |                  |                     | 7                                                  |
|                                                                               | xcf32p<br>bypass  | xcf32p<br>bypass | xc95144xi<br>bypass | xccace<br>bypass | xc5vsx50t<br>bypass |                                                    |
|                                                                               | TDO               |                  |                     |                  |                     | -                                                  |
|                                                                               |                   |                  |                     |                  |                     | Get Device JD                                      |
|                                                                               |                   |                  |                     |                  |                     | Get Device Signature/Usercode                      |
|                                                                               |                   |                  |                     |                  |                     | Add SPI/BPI Flash                                  |
| MPACT Processes ++ C & X                                                      |                   |                  |                     |                  |                     | Assign New Configuration File                      |
| Available Operations are:<br>Get Device ID                                    |                   |                  |                     |                  |                     | Set Programming Properties<br>Set Erase Properties |
| <ul> <li>Get Device Signature/Usercode</li> <li>Read Device Status</li> </ul> |                   |                  |                     |                  |                     | Launch File Assignment Wizard<br>Set Jarget Device |
|                                                                               |                   |                  |                     |                  |                     |                                                    |
|                                                                               |                   |                  |                     |                  |                     |                                                    |
|                                                                               |                   |                  |                     |                  |                     |                                                    |
|                                                                               |                   |                  |                     |                  |                     |                                                    |
|                                                                               | 9                 | Boundary Scan    |                     |                  |                     |                                                    |
| Console                                                                       |                   |                  |                     |                  |                     | +□ <i>8</i> ×                                      |
| done.                                                                         |                   |                  |                     |                  |                     | ^                                                  |
| FROGRESS_END - End Operation.<br>Elapsed time = 0 sec.                        |                   |                  |                     |                  |                     |                                                    |
| <                                                                             |                   |                  |                     |                  |                     | >                                                  |
| 🔋 Console 🔕 Errors 🔬 Warnings                                                 |                   |                  |                     |                  |                     |                                                    |
|                                                                               |                   |                  |                     |                  |                     | Cable UCD II. ( ABLe                               |

Figure 18: Assign New Configuration File.

| - → × ↑ 📒 « EE_499 > ISE > parametric_IIR_filter >                          |                    |                                                           | ~                                      | Ö                 | ,≏ Se                                 | arch parametri | c_IIR_filter |
|-----------------------------------------------------------------------------|--------------------|-----------------------------------------------------------|----------------------------------------|-------------------|---------------------------------------|----------------|--------------|
| Organize • New fold                                                         | ler                |                                                           |                                        |                   |                                       | == •           |              |
| A Quick access                                                              | Name               | ^                                                         | Date modified                          |                   |                                       | pe             | Size         |
| Desktop 🖈                                                                   | 🛃 _ngo             |                                                           | 5/12/2020                              | 2:53 PM           | Fi                                    | le folder      |              |
|                                                                             | _xmsgs             | _xmsgs                                                    |                                        | 5/12/2020 2:55 PM |                                       |                | File folder  |
| Downloads *                                                                 | 🧧 iseconfig        |                                                           | 5/12/2020                              | 12:47 PN          | / Fi                                  | le folder      |              |
| 🔮 Documents 🖈                                                               | xinx_auto_0        | xdb                                                       | 5/12/2020 2:53 PM<br>5/12/2020 2:34 PM |                   |                                       | le folder      |              |
| Fictures 📌                                                                  | a xst              |                                                           |                                        |                   |                                       | File folder    |              |
| Creating_Xilinx_I                                                           | o top_level.bit    |                                                           | 5/12/2020                              | 2:55 PM           | B                                     | TFile          | 2,           |
| <ul> <li>Images</li> <li>SMILE_Lab_REU_</li> <li>Tutorial Report</li> </ul> |                    | Type: BIT File<br>Size: 2.38 MB<br>Date modified: 5/12/20 | 020 2:55 PM                            |                   |                                       |                |              |
| Dropbox                                                                     |                    |                                                           |                                        |                   |                                       |                |              |
| .dropbox.cache v                                                            | <                  |                                                           |                                        |                   |                                       |                |              |
|                                                                             | ame: top_level.bit |                                                           |                                        | ~                 | All Design Files (*.bit *.rbt *.nky ~ |                |              |

Figure 19: Selecting the generate programming file (.bit) to program the FPGA.

9. Right click on the device **xc5vsx50t** and click **Program**. See **Figure 20**. Now the FPGA is programmed.

| r                                                                                                                                                                                   |                                   |                  |                     |                            |               |                                  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|------------------|---------------------|----------------------------|---------------|----------------------------------|
| ISE iMPACT (P.20131013) - [Boundary Scan]                                                                                                                                           | 1                                 |                  |                     |                            |               | - 🗆 ×                            |
| Eile Edit View Operations Output                                                                                                                                                    | Debug <u>W</u> indow <u>H</u> elp |                  |                     |                            |               | - 6                              |
| 🗋 🏓 🛃 👗 🛍 ն 🗙 🖽 🖽 😂                                                                                                                                                                 | 🔉 ii 🏭 🔁 🖬 ,                      | ₽ k?             |                     |                            |               |                                  |
| IMPACT Flows ↔ □ & ×                                                                                                                                                                | ]                                 |                  |                     |                            |               |                                  |
| Boundary Scan     System ACE     Create PROM File (PROM File Format     WebTalk Data                                                                                                | TDI <b>Examp</b><br>xef32p<br>tDO | xcf32p<br>bypass | x:95144xl<br>bypass | z suse<br>xccace<br>bypass | xc5v<br>top_k |                                  |
| MPACT Processes ↔ □ ♂ ×<br>Available Operations are:                                                                                                                                |                                   |                  |                     |                            |               | Launch File Assignment Wizard    |
| <ul> <li>Program</li> <li>Get Device Signature/Usercode</li> <li>Get Device Signature/Usercode</li> <li>Read Device Sidnus</li> <li>One Step JSVF</li> <li>One Step JSVF</li> </ul> |                                   |                  |                     |                            |               | Set Jørget Device                |
|                                                                                                                                                                                     | <b>\$</b>                         | Boundary Scan    |                     |                            |               |                                  |
| Console                                                                                                                                                                             |                                   |                  |                     |                            |               | +- 🗆 🗗                           |
| <pre>① INF0:1MPACT:501 - '5': Added</pre>                                                                                                                                           | Device xc5vsx50t s                | uccessfully.     |                     |                            |               | >                                |
| Console 🙆 Errors 🧘 Warnings                                                                                                                                                         |                                   |                  |                     |                            |               |                                  |
|                                                                                                                                                                                     |                                   |                  |                     | Config                     | uration PI    | atform Cable USB II 6 MHz usb-hs |

Figure 20: Program the generated programming file to the FPGA.

### **Graphical User Interface**

The graphical user interface (GUI) provides a visual guide to design the filter response, generate the fixed-point coefficients, and communicate those coefficients to the FPGA via serial communication. This GUI is built in Python 3 using the PyQt5 graphics library. Custom class and functions were developed for the fixed-point filter design of the biquad IIR filter.



Figure 21: Python based GUI.

#### Using the GUI

- 1. In a preferred directory unzip the file **Parametric\_IIR\_Filter\_GUI.zip** to get the GUI source code. This folder contains to subfolders called **PySP** and **GUI**. These two directories must be in the same parent directory. The command line (or terminal) will be used to launch the GUI within the Python environment.
- 2. Open a command line terminal of choice that can be used to run Python 3 applications with the required libraries (i.e. this may be a virtual environment for some users). Navigate into the **GUI** directory using the "cd" command.
- 3. Before running the command to start the GUI, it is necessary to know the COM port that the USB UART breakout board is communicating over. For example, if Windows is being used, then the COM port can be found in the **Device Manager** control panel. **Figure 22** shows that the breakout board is communicating on "COM10." For other operating systems finding the communication port will differ.



Figure 22: Windows Device Manager to find COM port for USB to UART breakout.

4. In the terminal run the command **python main.py --com\_port** [*COM port name*], where *COM port name* is the name of the communication port discussed in **step 3**. See **Figure 23**.



Figure 23: Example of command to start GUI.



Figure 24: How the GUI looks when opened.

5. Adjust the gain, center-frequency, and bandwidth as desired. As the sliders are adjusted the frequency response and pole-zero plot will reflect the expected response of the filter. Once the desired filter response is obtained, click the **Send Coefficients** button to transmit the filter coefficients to the FPGA.

### **Testing and Verification**

The system is ready to be tested. A function generator is used to supply the input signal to the ADC. The Pmod AD1 ADC allows an input voltage range of 0V - 3.3V, so have the function generator output be within this range. Hook the function generators probe to the ADC's analog input on channel 1 (A1). Next, the two channels of the oscilloscope are attached to measure the original input signal and resulting filtered output signal. The comparison is useful to identify that the magnitude frequency response corresponds to the design. One oscilloscope probe is connected to the DAC output on channel 1 to measure the filtered signal and the second oscilloscope probe is connected on channel 2 of the DAC to measure to original signal sampled from the function generator.



Figure 25: The testing and verification setup diagram.



Figure 26: Test and verification setup.

The output from the DAC of the filtered signal will have a magnitude scaled down by a factor of 4. This is ensuring the DAC will never be the source of saturation or encounter overflow that will corrupt the signal. Below are several test cases that verify the desired operation of parametric IIR implementation.



*Figure 27:* All pass, unity gain of signal. The input signal is given in the color blue and the output signal is the color yellow. However, since the filter is unity gain across all frequencies, the signals in the oscilloscope output are nearly on-top of one another.



Figure 28: The parametric EQ parameters specified were G=+10.0dB,  $F_c = 1000Hz$ , BW=632 Hz. The input signal (blue) is a 1000 Hz sine. The output signal (yellow) is the 10dB amplified.



Figure 29: The parametric EQ parameters specified were G=-10.0dB,  $F_c = 1000Hz$ , BW=632 Hz. The input signal (blue) is a 1000 Hz sine. The output signal (yellow) is the 10dB attenuated.



Figure 30: The parametric EQ parameters specified were G=+15.0dB,  $F_c = 9000Hz$ , BW=812 Hz. The input signal (blue) is a 1000 Hz square wave. Notice, the output signal (yellow) has the 9<sup>th</sup> harmonic amplified (9000Hz) by about 15dB.



Figure 31: The parametric EQ parameters specified were G=+15.0dB,  $F_c = 3000Hz$ , BW=66 Hz. The input signal (blue) is a 1000 Hz square wave. Notice, the output signal (yellow) has the  $3^{rd}$  harmonic amplified (3000Hz) by about 15dB.



Figure 32: The parametric EQ parameters specified were G=+15.0dB,  $F_c = 55Hz$ , BW=40 Hz. The input signal (blue) is a 1000 Hz sine wave. Notice, the output signal (yellow) is extremely noisy and corrupted. This is due to the fixed-point poles being outside the unit circle. This is an example of the difficulties of converting an infinite precision filter design to a fixed-point design.

## References

- [1] A. V. Oppenheim and R. W. Schafer, *Discrete-time signal processing*. Harlow: Pearson, 2014.
- R. Bristow-Johnson, "RBJ Audio-EQ-Cookbook"," *RBJ Audio-EQ-Cookbook Musicdsp.org* documentation, 04-May-2005. [Online]. Available: https://www.musicdsp.org/en/latest/Filters/197-rbj-audio-eq-cookbook.html. [Accessed: Feb 2020].
- [3] D. G. Manolakis and V. K. Ingle, *Applied digital signal processing: theory and practice*. Cambridge, U.K.: Cambridge University Press, 2011. ch. 15, pp. 902-967.
- [4] SparkFun, SparkFun USB UART Serial Breakout CY7C65, Accessed on: May 12, 2020.
   [Online]. Available: https://www.sparkfun.com/products/13830
- [5] "Pmod DA2: Two 12-bit D/A Outputs," *Digilent*. [Online]. Available: https://store.digilentinc.com/pmod-da2-two-12-bit-d-a-outputs/. [Accessed: Apr-2020].
- [6] "Pmod AD1: Two 12-bit A/D Inputs," *Digilent*. [Online]. Available: https://store.digilentinc.com/pmod-ad1-two-12-bit-a-d-inputs/. [Accessed: Apr-2020].
- [7] Xilinx, *ML505/ML506/ML507 Evaluation Platform User Guide*, UG347 datasheet. May. 2011.