# MASSACHUSETTS INSTITUTE OF TECHNOLOGY DEPARTMENT OF ELECTRICAL ENGINEERING AND COMPUTER SCIENCE 

### 6.111 Introductory Digital Systems Laboratory <br> Fall 2019

## Lecture PSet \#3 of 8

Due: Thu, 14:30 09/19/2019
Note: Submit PDF online
Optional docx available for submission

Problem 1. Interleaving [This problem is based on the implementation of a digital communications research project at MIT. When facing a tough problem, coming up with a solution is easier when the problem is broken down to simpler smaller blocks. The solution to this part together with parts 2 and 3 in future Ipsets will form the complete solution.]

For many communications systems, a forward error correcting (FEC) code such as a convolution code, is used during transmission. This will allow the receiver to correct erroneous bits when errors occur randomly in a coded sequence. [More on FEC in future Ipsets.] However, the bursty nature of noise will often wipe out large number of adjacent data bits - defeating the convolution code. A simple solution is to interleave the data bits of a four byte packet so that adjacent data bits are spaced out in the transmitted sequence. Instead of sending all 8 bits of the byte 0 , the low order bit pair of bytes $3,2,1$, and 0 (starting at the LSB end) are transmitted followed by the next set of bit pairs until all bits are transmitted. This is implemented in many satellite communication systems ${ }^{1}$.

(see other side)

[^0](A) Implement a Verilog module that will interleave 4 bytes as described above.

```
module interveaver(
    input [7:0] byte0, // 00
    input [7:0] byte1, // 0E
    input [7:0] byte2, // 8C
    input [7:0] byte3, // 03
    output [7:0] out0,
    output [7:0] out1,
    output [7:0] out2,
    output [7:0] out3
    );
    assign out0 =
    assign out1 =
    assign out2 =
    assign out3 =
endmodule
```

There are multiple implementations. To receive credit your interleaver must encode this input [ $\mathbf{O O} \mathbf{0 E} \mathbf{8 C} \mathbf{0 3}$ ] to the following output [ $\mathbf{C 8} \mathbf{3 C} \mathbf{0 0} 20$ ]. This will ensure compatibility with the deinterleaver. [This Verilog was used in a research project.]
(B) Write the Verilog for a deinterleaver. Any interesting observation?

## Problem 2 TMDS

In HDMI video, the pixel and audio data are transmitted down wires at extremely high data rates. Depending on the resolution and version of HDMI, up to 18 Gbits per second of data may need to get transmitted using three separate channels (we'll talk about this in Lecture 5). That's a lot of 1's and 0's to be transmitted. Unfortunately sending a lot of 1's and 0's means transitioning the voltage on the line at ${ }^{\sim} \mathrm{GHz}$ rates, which means the wires can be giving off tons of RF noise which can be extremely detrimental to the whole process (red pixel info interferes blue pixel info).

In order to at least partially mitigate high frequency value transitions, HDMI encodes its data using a scheme known as Transmission Minimized Differential Signaling (TMDS). In this scheme, the number of $1 \rightarrow 0$ or $0 \rightarrow 1$ transitions in a portion of data is reduced at the expense of sending slightly more bits overall. Specifically, TMDS will take every 8bits of data and transform it into 10 bits for sending. This problem concerns the first of those extra bits (the tenth bit we'll address in a future homework) So to clarify, for this problem we'll be creating 9 bits to represent 8 bits:

The strategy of TMDS is to take an input byte $X$ with bits $\left\{x_{7} x_{6} x_{5} x_{4} x_{3} x_{2} x_{1} x_{0}\right\}$ and generate a processed output byte $Y$ with bits $\left\{y_{7} y_{6} y_{5} y_{4} y_{3} y_{2} y_{1} y_{0}\right\}$ from one of two options:

1. Option One:
a. The original Isb is assigned to the Isb of the new data frame: $y_{0}=x_{0}$
b. The remaining 7 output bits are the XOR of the preceding two input bits as expressed: $y_{n}=x_{n} \oplus x_{n-1}$ for $7 \geq n \geq 1$ where $n$ is the bit number
2. Option Two:
a. The original Isb is assigned to the Isb of the new data frame: $y_{0}=x_{0}$
b. The remaining 7 output bits are the XNOR of the preceding two input bits as expressed $y_{n}=\overline{\left(x_{n} \oplus x_{n-1}\right)}$ for $7 \geq n \geq 1$ where $n$ is the bit number
3. $Y$ becomes the option with fewer internal transitions. If Option 1 is chosen, append a 1 as the ninth bit else, append a 0 as the ninth bit.
4. Send all 9 bits.

On the receiving side, the system receives packet $Z$ with bits $\left\{z_{8} Z_{7} Z_{6} Z_{5} Z_{4} Z_{3} Z_{2} Z_{1} Z_{0}\right\}$ and builds up a decoded byte $W$ with bits $\left\{w_{7} w_{6} w_{5} w_{4} w_{3} w_{2} w_{1} w_{0}\right\}$ using the following process:

1. Use the ninth bit to determine if the data was XOR or XNOR processed
2. If XOR:
a. The received Isb is assigned to the Isb of the new data frame: $w_{0}=z_{0}$
b. The remaining 7 output bits are the XOR of the preceding two input bits as expressed: $w_{n}=z_{n} \bigoplus w_{n-1}$ for $7 \geq n \geq 1$ where $n$ is the bit number
3. If XNOR:
a. The received Isb is assigned to the Isb of the new data frame: $w_{0}=z_{0}$
b. The remaining 7 output bits are the XNOR of the preceding two input bits as expressed: $w_{n}=\overline{\left(z_{n} \bigoplus w_{n-1}\right)}$ for $7 \geq n \geq 1$ where $n$ is the bit number

Carry out the following calculations (note you should be able to "check" your math by making sure you can decode what you create using the scheme provided up above):

Part A) Our input data byte is $\mathbf{8}^{\prime} \mathbf{b 1 0 1 0 \_ 0 1 0 1 :}$
i) Within the data byte how many $0 \rightarrow 1$ or $1 \rightarrow 0$ transitions are there? :
ii) What would processing the data byte with Option 1 look like:
iii) What would processing the data byte with Option 2 look like:
iv) Which one has fewer transitions? If Option 1, add a 1 as a ninth bit, else add a 0 as the ninth bit. What are the nine bits sent?:

Part B) Our input data byte is $\mathbf{8}^{\prime} \mathbf{b 1 1 1 1}$ _1111:
i) Within the data byte how many $0 \rightarrow 1$ or $1 \rightarrow 0$ transitions are there?:
ii) What would processing the data byte with Option 1 look like:
iii) What would processing the data byte with Option 2 look like:
iv) Which one has fewer transitions? If Option 1, add a 1 as a ninth bit, else add a 0 as the ninth bit. What are the nine bits sent?:

Part 2) We won't build the entire TMDS system today, but one module that is needed to get it working is a "one-tallier" that takes in a byte and returns the number of 1's present in it. For example:

- Input Byte: 8'b1011_1100: has a one tally of five
- Input Byte: $8^{\prime} b 0000 \_1100$ : has a one tally of two

Build a module in SystemVerilog that takes in one input (the byte being analyzed) and produces an output that indicates the one tally. The module should be purely combinational since we need it to be fast and low-latency. (Do not overthink this. This should be a pretty simple answer. We'll worry about what needs to happen because it is simple later)

```
module tallier(
    input [7:0] byte_in,
    output logic [2:0] tally_out
    );
// Your Verilog
endmodule
```


[^0]:    ${ }^{1}$ from http://www.ti.com/lit/an/swra113a/swra113a.pdf

