LABORATORY FFT

5Digit SS:



# LAB FFT: INTRODUCTION TO FAST FOURIER TRANSFORM (10 points)

In this lab you will be introduced to the design for a Fast Fourier Transform (FFT). The FFT is one of the most important DSP objects and is used not only to compute an approximation of the Fourier Transform, but also to enable fast convolution, a very time consuming filtering operation when done in the time domain.

In the **pre-lab** you will compute with "pencil-and-paper" the results you later expect in your design implementation. In the **design part** you will design an 8 point radix-2 FFT using the principle of decimation in frequency.

# Lab Objectives

After completing this lab you should be able to

- Develop a radix-2 FFT and compute test data
- Understand the difference between DFT and FFT
- Design and simulate FFT using the principle of decimation in frequency using Quartus

**Pre-lab** (3 points)

The following figure shows the 8 point radix-2 FFT using the principle of decimation in frequency:



Fig. 1

LABORATORY FFT

5Digit SS:\_\_\_\_\_

From the signal flow graph in Fig.1, determine for each stage the number of blocks required from each type of butterfly.

WITH

FPGAs

|                               | 1. stage | 2. stage | 3. stage |
|-------------------------------|----------|----------|----------|
| Butterfly with w <sup>0</sup> |          |          |          |
| Butterfly with w <sup>1</sup> |          |          |          |
| Butterfly with w <sup>2</sup> |          |          |          |
| Butterfly with w <sup>3</sup> |          |          |          |

2. Redraw the radix-2 signal flow graph from **Fig.1** such that the butterfly operations do not overlap and input/output are in natural rather than bit-reverse order, by completing the following figure:





3. Each butterfly  $k \in [0,3]$  performs a complex value operation of the type

D = A+B; and  $E = (A-B)W^k$ 

Complete the following table for the given input values A=100+j\*110; B=- 40+j\*10

|                               | <b>D_real</b> | D_imag | E_real | E_imag |
|-------------------------------|---------------|--------|--------|--------|
| Butterfly with w <sup>0</sup> |               |        |        |        |
| Butterfly with w <sup>1</sup> |               |        |        |        |
| Butterfly with w <sup>2</sup> |               |        |        |        |
| Butterfly with w <sup>3</sup> |               |        |        |        |

Hint: Remember **W** =exp(-j\* $2\pi/8$ )

## 4. Using MatLab, compute for x=100:100:800 the FFT, X = round(fft(x)), and complete the table:

|          | X[0] | X[1] | X[2] | X[3] | X[4] | X[5] | X[6] | X[7] |
|----------|------|------|------|------|------|------|------|------|
| Real     |      |      |      |      |      |      |      |      |
| Imag     |      |      |      |      |      |      |      |      |
| abs(X[k] |      |      |      |      |      |      |      |      |
| )        |      |      |      |      |      |      |      |      |

LABORATORY FFT

5Digit SS:\_\_\_\_\_



# VHDL Design-lab (7 points)

Follow the directions below to implement the 8-point radix-2 FFT circuit.

#### A. Getting Started

- 1. On the desktop double click on **Engineering folder** and start version 9.1 of **Quartus II**. <u>Do not</u> use Quartus version 10 since it does not has a build-in simulator.
- 2. You should not save anything on the local hard disk. You will have to use a USB flash drive, or your "mapped" home directory to save the files. Create (if not done in a previous lab) a new folder named **DSPwFPGAs** on your mapped network drive.

#### B. Design the magnitude circuit

- 1. For an absolute value of a complex number x+jy the equation  $r=\sqrt{(x^2+y^2)}$  needs to be computed. An approximation to this task should be designed next. Generate the new Quartus project magnitude.
- 2. Design a magnitude.vhd circuit using the following approximation:  $r=\max(x,y)+\min(x,y)/4$ . This approximation is bias free and has an error of less than 10%. Design the circuit with inputs *x* and *y*, and output *r*. All data should be in the signed 16-bit integer format; do not use any flip-flops.

| nagnitude.vwf                              |             |          |                 |                                                                |
|--------------------------------------------|-------------|----------|-----------------|----------------------------------------------------------------|
|                                            | Master T    | ime Bar: | 0 ps 💽          | Pointer: 24.84 ns Interval: 24.84 ns Start: End:               |
| <b>▶ A</b> <del>X</del> €<br>■ <b>M</b> \} |             | Name     | Value at<br>Ops | 0 ps 160,0 ns 320,0 ns 480,0 ns 640,0 ns 800.0 ņs<br>0 ps<br>1 |
|                                            | <b>D</b>    | ±×       | S 4096          | 4096 X 2896 X 0 X -2896 X -4096 X -2896 X 0 X 2896 X           |
|                                            | <b>1</b> 7  | Шу       | S 0             | 0 2896 4096 2896 0 -2896 -4096 -2896                           |
| — ~ ~ ~<br>ふ 凝 ~ ~                         | <b>@</b> 34 | 1 E      | S 4096          | 4096 X 3620 X 4096 X 3620 X 4096 X 3620 X 4096 X 3620 X        |
| X2 X8 <b>% \$</b>                          |             |          |                 |                                                                |
|                                            |             |          |                 | Magnitude Check by Dr. Uwe Meyer-Baese                         |
|                                            | <b>I</b>    |          | Þ               |                                                                |

3. Match the following simulation for a testbench:

#### C. Design the W1 and W3 Butterflies

4. Download the files bf0.vhd and bf1.vhd from the class webpage and place it in your **DSPwFPGAs** folder. These are the butterfly designs for  $w^0=1$  and  $w^1=-j\pi/4$ . Now design the  $w^2$  butterfly bf2.vhd using the  $w^0$  butterfly and the  $w^3$  butterfly bf3.vhd using  $w^1$ .

5Digit SS:\_\_\_\_\_

LABORATORY FFT



5. Generate a new project  $bf_tb$ . Develop a testbench  $bf_tb$ . vhd using the data from the Prelab i.e., A=100+j\*110; B=-40+j\*10 and match the following simulation for a testbench:

| <b>n</b> bf             | _tb.vwf      |                   |             |                      |
|-------------------------|--------------|-------------------|-------------|----------------------|
|                         | Master Tin   | ne   1.675 ns 🕂 P | oir 4.35 ns | Inter -7.33 ns S E   |
|                         |              |                   | Value at    | 0 ps 4.0, ns 8.0, ns |
| A                       |              | Name              | 11.68 ns    |                      |
| Æ                       | <b>₽</b> 0   | 🛨 Are             | S 100       | 100                  |
| €                       | <b>1</b> 7   | 🗉 Aim             | S 110       | 110                  |
|                         | <b>3</b> 4   | 🖭 Bre             | S -40       | -40                  |
| <u>åå</u>               | <b>1</b> 51  | 🗉 Bim             | S 10        | 10                   |
| 23                      | 68           | 🛨 Dre0            | S 60        | 60                   |
|                         | <b>@</b> 85  | 🗉 Dim0            | S 120       | 120                  |
| ×                       | 102          | 🛨 EreO            | S 140       | 140                  |
| ×××<br>0                | 119          | 🗉 EimO            | S 100       | 100                  |
|                         | <b>⊚</b> 136 | 🛨 Dre1            | S 60        | 60                   |
| л.<br>z                 | <b>@</b> 153 | 🗉 Dim1            | S 120       | 120                  |
|                         | l70 🕞        | 🗉 Ere1            | S 169       | 169                  |
| Nº I                    | l 187 🕢      | 🗉 Eim1            | S -28       | -28                  |
| 사람                      | i 204 i 🔂    | 🛨 Dre2            | S 60        | 60                   |
| 전                       | i 221 i 🔂    | 🗉 Dim2            | S 120       | 120                  |
| A <sup>e</sup> c<br>INU | <b>@</b> 238 | 🗉 Ere2            | S 100       | 100                  |
| ×88<br>√e               | i 255 🔂      | 🗉 Eim2            | S -140      | -140                 |
|                         | <b>@</b> 272 | 🛨 Dre3            | S 60        | 60                   |
|                         | <b>@</b> 289 | 🗉 Dim3            | S 120       | 120                  |
| <u>X2</u>               | ig 306 🕢     | 🖭 Ere3            | S -28       | -28                  |
| <u>×</u> B              | 323          | 🗉 Eim3            | S -169      | -169                 |
| 影                       |              |                   |             |                      |
| ₽↓                      | 4            |                   | Þ           |                      |

## D. Completion of the 8-point radix-2 FFT

- 1. Generate a new project dif8. Develop a design dif8. vhd using the signal flow graph you developed in the pre-lab. Your dif8. vhd design should have input clk and x and output a magnitude vector r with 8 elements.
- 2. The imaginary input to the FFT is zero. The real input x should be put in a shift register such as the shift register we have used in the direct form FIR filter. Your output r should also be using registers. Do not use any registers for the butterfly or magnitude computations.
- 3. Copy and paste the necessary subsystems components and then wire them as determined in the pre-lab. You need 12 butterfly components and 8 magnitude component instantiations.
- 4. Simulate your design and compare the results shown by the provided scopes with the data you computed for the pre-lab for x=100:100:800.
- 5. Try to match the following simulation:

LABORATORY FFT



5Digit SS:\_\_\_\_\_

| n dif8.v            | wf           |                 |                |                        |                      |                       |                       |                       |                                |        |
|---------------------|--------------|-----------------|----------------|------------------------|----------------------|-----------------------|-----------------------|-----------------------|--------------------------------|--------|
|                     | Master Tin   | ne Bar:         | Pointe         | :: 30.1 ns             | Interv               | al:                   | Start:                |                       | End:                           |        |
| ∖a<br>₩€            |              | Name            | 0 ps 12        | 3 <sub>i</sub> 0 ns 25 | 56 <sub>1</sub> 0 ns | 384 <sub>,</sub> 0 ns | 512 <sub>,</sub> 0 ns | 640 <sub>,</sub> 0 ns | 768,0 ns 896,                  | 0 ns   |
|                     | ∎>0          | clk             |                |                        |                      |                       |                       |                       |                                | $\Box$ |
| <b>86</b> 2.5       | <b>1</b>     | Ξ×              | 100            | 200 X 3                | 300 X 4              | 00 X 50               | 00 X 600              | χ 700 χ               | BOO X O                        | _      |
|                     | <b>@</b> 18  | П Г             | 1, 1, 0, 0, 0, | 0, 19728, 9728         | 4080, 972            | (7392, 4864)          | 6752, 4864 (16        | 16, 1344 (1104, 134   | 4 <del>X</del> 5216, 2432X5216 | , 2432 |
| ∧≌ ∞∞<br>0 1        | <b>@</b> 19  | [0]1            | 3276 0         | X 100                  | X 300                | 600                   | (1000)                | 1500 X 2100           | X 2800 X 36                    | 500    |
| ŭń.<br>zva          | <b>@</b> 36  | <b>□</b> - (1]  | 3276 0         | X 100                  | X 287                | 501                   | 662                   | 858 X 1011            | X 1064                         |        |
|                     | <b>6</b> 253 | <b>□</b> - r[2] | 3276 0         | X 100                  | X 225                | X 25                  | io X                  | 350 X 475             | χ 500                          |        |
| VE VE               | <b>@</b> 70  | (3)             | 3276 0         | X 100                  | X 147                | (169)                 | 278                   | 289 X 353             | χ 441                          |        |
|                     | <b>@</b> 87  | (4]             | 3276 0         | _X1                    | 00                   | 20                    | 10 X                  | 300                   | χ 400                          |        |
|                     | 104          | (5) I           | 3276 0         | X 100                  | X 147                | (169)                 | 278                   | 289 X 353             | χ 441                          |        |
|                     | 121          | [6]ı            | 3276 0         | X 100                  | X 225                | 25                    | i0 X                  | 350 X 475             | χ 500                          |        |
| <u>₩</u> <b>2</b> ↓ | <b>@</b> 138 | ₫-r[7]          | 3276 0         | X 100                  | X 287                | 501                   | 662                   | 858 X 1011            | χ 1064                         |        |
|                     |              |                 |                | DIF8 sim               | ulation b            | y Dr. Uw              | e Meyer-E             | Baese                 |                                |        |
|                     |              | •               |                |                        |                      |                       |                       |                       |                                | ►      |

6. Now run a full compilation. From the report file and the **Classic Timing Analyzer Tool** (**Processing** menu) determine

| Total logic elements               | = | <br>_   |
|------------------------------------|---|---------|
| Embedded Multiplier 9-bit elements | = | <br>-   |
| Total memory bits                  | = | <br>-   |
| Registered Performance             | = | <br>MHz |

Enter these resource and performance data also in your dif8.vhd header file.

#### E. DE2 Implementation of the FFT Design

- 1. Download the MatLab file fun4fft.m and seg7\_bar.vhd from the class webpage and place it in your **DSPwFPGAs** folder. Run the fun4fft.m script in MatLab. It will generate the sine LUTs for 0, 6, 12, and 18 kHz.
- 2. Start Quartus II and build a new project called DE2\_lab7. As device select EP2C35F672C6 and load the pin assignment file DE2\_pin\_small.csv (from lab5 folder or BlackBoard) into Quartus II using Assignments-> Import Assignments ...
- 3. Copy from your DE2\_lab5 folder into the DE2\_lab7 folder the following files: DE2\_lab5.vhd, audio\_pll.vhd, audio\_pll.qip, audio\_pll.cmp, i2c\_config.vhd, i2c\_controller.vhd, and audio\_dac.vhd. Rename the file DE2\_lab5.vhd to DE2\_lab7.vhd and change the entity name to DE2\_lab7.

5Digit SS:





4. Remove the fir component from DE2\_lab7.vhd and define in the signal section and instantiate dif8 and seg7\_BAR as a component into the DE2\_lab7.vhd as follows:

```
C4: dif8 PORT MAP(clk=>DACLRCK, x=>x, r=>r);

R0: seg7_BAR PORT MAP (idig => CONV_STD_LOGIC_VECTOR(r(0)/4096,4), oseg => hex7);

R1: seg7_BAR PORT MAP (idig => CONV_STD_LOGIC_VECTOR(r(1)/4096,4), oseg => hex6);

R2: seg7_BAR PORT MAP (idig => CONV_STD_LOGIC_VECTOR(r(2)/4096,4), oseg => hex5);

R3: seg7_BAR PORT MAP (idig => CONV_STD_LOGIC_VECTOR(r(3)/4096,4), oseg => hex4);

R4: seg7_BAR PORT MAP (idig => CONV_STD_LOGIC_VECTOR(r(4)/4096,4), oseg => hex3);

R5: seg7_BAR PORT MAP (idig => CONV_STD_LOGIC_VECTOR(r(5)/4096,4), oseg => hex2);

R6: seg7_BAR PORT MAP (idig => CONV_STD_LOGIC_VECTOR(r(6)/4096,4), oseg => hex1);

R7: seq7_BAR PORT MAP (idig => CONV_STD_LOGIC_VECTOR(r(6)/4096,4), oseg => hex1);
```

Define the required signals in the correct width. For convenience copy the definitions for S16 data type from the iir\_order1.vhd or fir.vhd file and place it in the signal definition section of DE2\_lab7.vhd. In the port list add hex2,...,hex7 to the available **OUT** ports.

- 5. Keep key(0) as global reset for the registers and the functionality of SW0...SW3 as in lab4. The signal dac should always be a register controlled by DACLRCK with key(0) as synchronous reset. Connect dac to the sum to observe the FFT input with the scope/headset.
- 6. Now run a full compilation. From the **Compilation Report** and the **Classic Timing Analyzer Tool (Processing** menu) for clock\_50 determine

| Total logic elements               | = | <br>-   |
|------------------------------------|---|---------|
| Embedded Multiplier 9-bit elements | = |         |
| Total memory bits                  | = |         |
| Registered Performance             | = | <br>MHz |
|                                    |   |         |

Enter these resource and performance data in your DE2\_lab7 VHDL header file.

7. Now download the DE2\_lab7.sop file to the board and observe with oscilloscope or head set. The hex0-7 display shows the FFT magnitude values in form of a "bar" graph. The letter \_,u,o,..8 are used. Complete the table below with your observations. For the HEX 7-segments specify the displayed letter. For the scope specify the function and frequency.

| SW3 | SW2 | SW1 | SW0 | HEX7 | HEX6 | HEX5 | HEX4 | HEX3 | HEX2 | HEX1 | HEX0 | Scope |
|-----|-----|-----|-----|------|------|------|------|------|------|------|------|-------|
| 0   | 0   | 0   | 1   |      |      |      |      |      |      |      |      |       |
| 0   | 0   | 1   | 0   |      |      |      |      |      |      |      |      |       |
| 0   | 1   | 0   | 0   |      |      |      |      |      |      |      |      |       |
| 1   | 0   | 0   | 0   |      |      |      |      |      |      |      |      |       |
| 1   | 1   | 1   | 1   |      |      |      |      |      |      |      |      |       |

#### F. Deliverables:

- 1. Solve the problems of the pre-lab. (3 points).
- 2. Complete this report. Print the VHDL files magnitude.vhd, bf2.vhd, bf3.vhd, dif8.vhd and DE2\_lab7.vhd and the 3 simulations from magnitude, bf\_tb and dif8 (7 points).

## Make sure your name and SS is on all pages you turn in!