# 2023 SOC Lab3 Report

## 1.Overview:

本次實驗要求利用 Stream 進行資料的傳輸,其他如 ap\_start 等其他通訊協定則要求利用 Axilite 傳輸,在 FIR 方面要求只能利用一個加法器和一個乘法器。

# 2.Block Diagram:



# 3.Operation:

從y[t] =  $\Sigma$  (h[i] \*x[t-i])這個式子,我們可以觀察到 FIR filter 運算的規律如下:(h[1] \*x[t-1])+ (h[2] \*x[t-2])...,每次需要 讀入一筆新的 data,而這筆 data 需要與 h[0]相乘,而上次讀入的 data 則是與 coef[1]相乘,以此類推,直到計算完11 個相乘,故y[t]的累加最後一項為(h[11] \*x[0])。假如data是依照讀入順序存在各個 address,我們就只需要用一個 pointer 指 向最新的 data address,從此 pointer 開始依序 accesses data BRAM,將讀出的 data 依序與coef[1]..., coef[11]相乘累加,即可完成 FIR filter運算。

# 4. Resourace Usage:

| 31 +                       | +       | ++       |           | +           | ++          |
|----------------------------|---------|----------|-----------|-------------|-------------|
| 32   Site Type             | Used    | Fixed    | Prohibite | d   Availab | le   Util%  |
| 33 +                       | +       | ++       |           | +           | ++          |
| 34   Slice LUTs*           | 194     | 0        |           | 0   5320    | 0.36        |
| 35   LUT as Logic          | 194     | 0        |           | 0   5320    | 00   0.36   |
| 36   LUT as Memory         | 0       | 0        |           | 0   1740    | 0.00   0.00 |
| 37   Slice Registers       | 116     | 0        |           | 0   10640   | 00   0.11   |
| 38   Register as Flip Flop | 113     | 0        |           | 0   10640   | 00   0.11   |
| 39   Register as Latch     | 3       | 0        |           | 0   10640   | 00   <0.01  |
| 40   F7 Muxes              | 0       | 0        |           | 0   2660    | 0.00        |
| 41   F8 Muxes              | 0       | 0        |           | 0   1330    | 0.00        |
| 42 +                       | +       | ++       |           | +           | ++          |
| 68 +                       |         |          |           |             |             |
| 69   Site Type   Used      | l I Fix | ed   Pro | hibited L | Available   | l Util% l   |
| 70 +                       | .       |          |           |             | -1          |
|                            |         | 0 1      |           | 440         | 1 0 00 1    |
| ·                          | )       | 0        | 0         |             | : :         |
| 72   RAMB36/FIFO*   6      | )       | 0        | 0         | 140         | 0.00        |
| 73   RAMB18   6            | )       | 0        | 0         | 280         | 0.00        |
| 74 +                       | -+      | +        | +         |             | -++         |

# **5.Timing Report:**



# **6.Simulation Waveform:**

## 0~1500ns:



## 1500~2300ns:



## 2300~3100ns:



#### 3100~4000ns:



## 4100~5000ns:

