

# **Homework 3 Report**

**Course:**

IL2234 HT25 Digital Systems Design and Verification using Hardware

Description Languages

**Student Name:**

Jinye Gong

**GitHub Repository:**

<https://github.com/kth-ees/il2234ht25-hw3-jinye-gong>

**Submission Date:**

2025-10-08

## Question 1:

Design an FSM that can detect an *input\_sequence* of 5 consecutive ones. Assume that a new input comes at every clock cycle. The output *detected* should be asserted at the same cycle when the 5<sup>th</sup> '1' is given to the input. It should remain asserted as long as the input remains '1'.

Module pinout

| Name           | Direction | Width | Control/Data | Description                          |
|----------------|-----------|-------|--------------|--------------------------------------|
| clk            | in        | 1     | Control      | Clock signal                         |
| rstn           | in        | 1     | Control      | Asynchronous active low reset        |
| input_sequence | in        | 1     | Data         | Input                                |
| detected       | out       | 1     | Data         | 1 if 5 consecutive ones are detected |

1. What should be the type of FSM machine?

**This state machine belongs to the Mealy type because its output is jointly determined by both the current state and the current input.**

2. Draw the state diagram for the FSM machine.



3. Derive the next state logic using D flops.

| state | 0     | 1 | 0 | 1 | WV.V <sub>0</sub>                            | 0   | 1   | 0 | 1 | WV.V <sub>0</sub>                            | 0   | 1   | 0 | 1 |
|-------|-------|---|---|---|----------------------------------------------|-----|-----|---|---|----------------------------------------------|-----|-----|---|---|
| A     | A     | B | 0 | 0 | 000                                          | 000 | 001 | 0 | 0 | 000                                          | 000 | 001 | 0 | 0 |
| B     | A     | C | 0 | 0 | 001                                          | 000 | 010 | 0 | 0 | 001                                          | 000 | 010 | 0 | 0 |
| C     | A     | D | 0 | 0 | 010                                          | 000 | 011 | 0 | 0 | 010                                          | 000 | 011 | 0 | 0 |
| D     | A     | E | 0 | 0 | 011                                          | 000 | 100 | 0 | 0 | 011                                          | 000 | 100 | 0 | 0 |
| E     | A     | E | 0 | 1 | 100                                          | 000 | 100 | 0 | 1 | 100                                          | 000 | 100 | 0 | 1 |
|       | state |   | w |   | V <sub>z</sub> V <sub>y</sub> V <sub>x</sub> |     |     | w |   | D <sub>2</sub> D <sub>3</sub> D <sub>4</sub> |     |     | w |   |

State Table                    Transition Table                    Excitation Table

| $\bar{v}_1$ | 00 | 01 | 11 | 10 | $D_2 = jv_2 + jv_1v_0$ |
|-------------|----|----|----|----|------------------------|
| $v_0$       | 0  | 0  | 1  | 0  |                        |
| $v_1$       | 0  | -  | -  | 0  |                        |
| $v_2$       | 0  | -  | -  | 1  |                        |
| $v_3$       | 0  | -  | -  | 0  |                        |

  

| $\bar{v}_1$ | 00 | 01 | 11 | 10 | $D_1 = j(\bar{v}_1v_0 + v_1\bar{v}_0)$ |
|-------------|----|----|----|----|----------------------------------------|
| $v_0$       | 0  | 0  | 0  | 0  |                                        |
| $v_1$       | 0  | 0  | -  | 1  |                                        |
| $v_2$       | 0  | -  | -  | 0  |                                        |
| $v_3$       | 0  | -  | -  | 1  |                                        |

| $\bar{v}_1$ | 00 | 01 | 11 | 10 | $D_0 = j\bar{v}_0\bar{v}_2$ |
|-------------|----|----|----|----|-----------------------------|
| $v_0$       | 0  | 0  | 0  | 1  |                             |
| $v_1$       | 0  | -  | -  | 0  |                             |
| $v_2$       | 0  | -  | -  | 1  |                             |
| $v_3$       | 0  | -  | -  | 0  |                             |

  

| $\bar{v}_1$ | 00 | 01 | 11 | 10 | $w = jv_2$ |
|-------------|----|----|----|----|------------|
| $v_0$       | 0  | 0  | 1  | 0  |            |
| $v_1$       | 0  | -  | -  | 0  |            |
| $v_2$       | 0  | -  | -  | 1  |            |
| $v_3$       | 0  | -  | -  | 0  |            |



6. Verify both structural and behavioral models and compare their results and waveforms together in your report.



The testbench shows that the output waveforms of the structural and behavioral models are identical, and both correctly perform the detection.

## Question 2:

Design a message conversion system with the conversion rule below:

For every cycle, if the input message bit is '0', toggle the current output bit; if the input message bit is '1', keep the output bit unchanged.

For example, let the input message be  $x$ , and the output message be  $z$ . Assuming  $z$  initially is '1'. Given the sequence of  $x = 10001110011010$ , the output sequence of  $z$  should be: 10100001000110. See the figure below.



Module pinout

| Name | Direction | Width | Control/Data | Description                   |
|------|-----------|-------|--------------|-------------------------------|
| clk  | in        | 1     | Control      | Clock signal                  |
| rstn | in        | 1     | Control      | Asynchronous active low reset |
| x    | in        | 1     | Data         | Input                         |
| z    | out       | 1     | Data         | Output                        |

- (1) Draw the state diagram of a **Mealy FSM** with the same behavior as described above.

conversion\_system\_mealy



- (2) Draw the state diagram of a **Moore FSM** with the same behavior as described above.

conversion\_system\_moore



- (3) Write a testbench for both FSMs and compare the timing, number of states, and the output waveforms of Mealy and Moore FSMs in your report.



### Number of states:

Both have 2 states (S0, S1).

### Timing:

- **Mealy:**
  - When  $x=0$ ,  $z$  toggles in the same cycle.
  - When  $x=1$ ,  $z$  holds in the same cycle.
- **Moore:**
  - When  $x=0$ ,  $z$  toggles in the **next cycle**.
  - When  $x=1$ ,  $z$  holds in the **next cycle**.

### Evaluations:

- In a **Mealy machine**,  $z$  responds in the **same cycle** as  $x$ .
- In a **Moore machine**,  $z$  is **delayed by one clock cycle** relative to  $x$ .

## Question 3:

A serial communication device has a begin-sequence (011010) that leads to the transmission of 32 bits on its *serData* input. After receiving the begin-sequence, the *outValid* output becomes 1, and the next 32 bits on *serData* are regarded as valid serial data of the communication device. After 32 clock cycles, *outValid* becomes 0 and the device returns to the first state, where it searches for the begin-sequence again.

Module pinout

| Name            | Direction | Width | Control/Data | Description                   |
|-----------------|-----------|-------|--------------|-------------------------------|
| <b>clk</b>      | in        | 1     | Control      | Clock signal                  |
| <b>rstn</b>     | in        | 1     | Control      | Asynchronous active low reset |
| <b>serData</b>  | in        | 1     | Data         | Input                         |
| <b>outValid</b> | out       | 1     | Data         | Output                        |

- (1) Create a state diagram to represent the moore FSM for this system, clearly showing all states, transitions, and places where the output is issued. Draw the FSM in your report.



- (3) Write a testbench and verify the functionality of your design.



The waveform demonstrates successful detection of the sequence 011010. Following this detection, the *outValid* signal is activated, enabling the complete transmission of the subsequent 32-bit data frame.

## Question 4:

Design and implement an *average calculator* that computes the average of  $n$   $m$ -bit input numbers, where  $n=2^k$  with  $k > 1$ , and  $m > 1$ . The module should begin computation when it receives a positive pulse on the `start` signal and assert the `done` signal once the average is ready.

Module parameters

| parameter        | Description      |
|------------------|------------------|
| <code>m</code>   | input bit width  |
| $n = 2^k, k > 1$ | number of inputs |

Module pinout

| Name                | Direction | Width | Control/Data | Description                   |
|---------------------|-----------|-------|--------------|-------------------------------|
| <code>clk</code>    | in        | 1     | Control      | Clock signal                  |
| <code>rstn</code>   | in        | 1     | Control      | Asynchronous active low reset |
| <code>start</code>  | in        | 1     | Control      | Input control signal          |
| <code>inputx</code> | in        | $m$   | Data         | Input data                    |
| <code>done</code>   | out       | 1     | Control      | Output                        |
| <code>result</code> | out       | $m$   | Data         | Output result                 |

1. Draw a schematic of your datapath in your report, including the components, their interfaces, and necessary control signals.



2. Draw a state diagram showing your controller's behavior in your report. In each state, show the control signals that are issued.



4. Show the wiring between the datapath and controller within the top-level module in your report.



5. Verify the functionality of your module with a testbench.



## Question 5:

The Taylor series expansion of  $\sin x$  is shown below.

$$\sin(x) = \sum_{n=0}^{\infty} \frac{(-1)^n}{(2n+1)!} x^{2n+1} = x - \frac{x^3}{3!} + \frac{x^5}{5!} - \frac{x^7}{7!} + \frac{x^9}{9!} - \dots$$

Design an accelerator that calculates the sin of  $x$  based on the Taylor series expansion of  $\sin x$ . The  $x$  signal is a 15-bit fraction and 1-bit integer,  $x \in [0, \frac{\pi}{2}]$ . The accelerator starts calculating the sin of  $x$  when it receives a positive pulse on the *start* signal. Accelerator should issue 1 on the *done* signal when the result is calculated after eight iterations. The accelerator has a 16-bit fractional output signal called *result*,  $\text{result}[0,1]$ .

Module pinout

| Name   | Direction | Width | Control/Data | Description                   |
|--------|-----------|-------|--------------|-------------------------------|
| clk    | in        | 1     | Control      | Clock signal                  |
| rstn   | in        | 1     | Control      | Asynchronous active low reset |
| start  | in        | 1     | Control      | Input control signal          |
| x      | in        | 16    | Data         | Input data                    |
| done   | out       | 1     | Control      | Output                        |
| result | out       | 16    | Data         | Output result                 |

1. Draw a schematic of your datapath in your report, including the components, interfaces, and necessary control signals. (Use the *sin\_coeff\_lut* module that is given for the coefficients.)



2. Draw a state diagram that shows the behavior of your controller in your report. In each state, show the control signals that are issued.



3. Show the wiring between the datapath and controller within the top-level module in your report.



6. Verify the functionality of your accelerator with a testbench.

X=0.5                    0100 0000 0000 0000

Sin(0.5)=0.47942554    0.011 1101 0101 1101



X=0                    0000 0000 0000 0000

Sin(0)=0                0.000 0000 0000 0000



X=0.25                0010 0000 0000 0000

Sin(0.25)= 0.24740396    0.001 1111 1010 1011

