

# Assignment 1 – Hamming codes

Arquiteturas de Alto Desempenho

Work done by:

- -Lúcia Sousa 93086
- -Rodrigo Martins 93264 Gr5 TP2



## Encoder Control Path



16 OR gates 57 AND gates



16 OR gates 37 AND gates

| C4 | C3 | C2 | C1 | CO | nR | а | b | С | d | Sel1 | Sel0 | Selpar | nSet | nRst |
|----|----|----|----|----|----|---|---|---|---|------|------|--------|------|------|
| 0  | 0  | 0  | 0  | 0  | 1  | 1 | 1 | 0 | 0 | 0    | 0    | 0      | 1    | 1    |
| 0  | 0  | 0  | 0  | 1  | 1  | 1 | 0 | 1 | 0 | 0    | 0    | 0      | 1    | 1    |
| 0  | 0  | 0  | 1  | 0  | 1  | 1 | 0 | 0 | 1 | 0    | 0    | 0      | 1    | 1    |
| 0  | 0  | 0  | 1  | 1  | 1  | 0 | 1 | 1 | 0 | 0    | 0    | 0      | 1    | 1    |
| 0  | 0  | 1  | 0  | 0  | 1  | 0 | 1 | 0 | 1 | 0    | 0    | 0      | 1    | 1    |
| 0  | 0  | 1  | 0  | 1  | 1  | 0 | 0 | 1 | 1 | 0    | 0    | 0      | 1    | 1    |
| 0  | 0  | 1  | 1  | 0  | 1  | 1 | 1 | 1 | 0 | 0    | 0    | 0      | 1    | 1    |
| 0  | 0  | 1  | 1  | 1  | 1  | 1 | 1 | 0 | 1 | 0    | 0    | 0      | 1    | 1    |
| 0  | 1  | 0  | 0  | 0  | 1  | 1 | 0 | 1 | 1 | 0    | 0    | 0      | 1    | 1    |
| 0  | 1  | 0  | 0  | 1  | 1  | 0 | 1 | 1 | 1 | 0    | 0    | 0      | 1    | 1    |
| 0  | 1  | 0  | 1  | 0  | 1  | 1 | 1 | 1 | 1 | 0    | 0    | 0      | 1    | 1    |
| 0  | 1  | 0  | 1  | 1  | 1  | 0 | 0 | 0 | 0 | 0    | 0    | 1      | 1    | 1    |
| 0  | 1  | 1  | 0  | 0  | 1  | 0 | 0 | 0 | 0 | 0    | 1    | 1      | 1    | 1    |
| 0  | 1  | 1  | 0  | 1  | 1  | 0 | 0 | 0 | 0 | 1    | 0    | 1      | 1    | 1    |
| 0  | 1  | 1  | 1  | 0  | 1  | 0 | 0 | 0 | 0 | 1    | 1    | 1      | 1    | 1    |
| 0  | 1  | 1  | 1  | 1  | 1  | 0 | 0 | 0 | 0 | 0    | 0    | 0      | 1    | 1    |
| 1  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0    | 0    | 0      | 1    | 0    |

 $nR = \overline{C4}$ 

 $a = \overline{C4}.\overline{C2}.\overline{C0} + \overline{C3}.C2.C1 + \overline{C4}.\overline{C3}.\overline{C2}.\overline{C1}$ 

 $b = \overline{C3}.C1.C0 + \overline{C3}.C2.\overline{C0} + \overline{C4}.\overline{C3}.\overline{C1}.\overline{C0} + C3.\overline{C2}.\overline{C1}.C0 + C3.\overline{C2}.\overline{C1}.C0$ 

 $c = \overline{C3}.\overline{C2}.C0 + \overline{C3}.\overline{C1}.C0 + \overline{C2}.\overline{C1}.C0 + C3.\overline{C2}.\overline{C0} + \overline{C3}.C2.C1.\overline{C0}$ 

 $d = \overline{C2.C1.\overline{C0}} + \overline{C3.C2.\overline{C1}} + \overline{C3.C2.C0} + C3.\overline{C2.\overline{C1}}$ 

Sel1 =  $C3.C2.\overline{C1}.C0 + C3.C2.C1.\overline{C0}$ 

Sel0 =  $\overline{C4}$ .C3.C2. $\overline{C0}$ 

Selpar =  $\overline{C4}$ .C3.C2. $\overline{C1}$  +  $\overline{C4}$ .C3.C2. $\overline{C0}$  + C3. $\overline{C2}$ .C1.C0

 $nRst = \overline{C4}$ 

# Encoder Data Path



### Decoder

#### decoder\_p encoder\_h decoder\_h →h10 s7 s5) P3 s4) y10 -y13 -P2 P1 s3) P0 s2) s1 s0 y7 -y14 -→ h0 p4 y5 -22 XOR gates 19 AND gates 3 delays 2 delays

### xor\_11\_bits



11 XOR gates

# Truth Table encoder\_h

| H0 = 50.54 |
|------------|
| H1 = S1.S5 |
| H2 = S2.S5 |
| H3 = S1.S6 |
| H4 = S2.S6 |
| H5 = S3.S7 |
| H6 = S1.S4 |
| H7 = S2.S4 |
| H8 = S3.S5 |
|            |

U0 - C0 C4

H9 = S3.S6

H10 = S3.S4

| Р3 | P2 | P1 | PO | H10 | Н9 | H8 | H7 | Н6 | H5 | H4 | Н3 | H2 | H1 | HO |
|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|
| 0  | 0  | 1  | 1  | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  |
| 0  | 1  | 0  | 1  | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  |
| 1  | 0  | 0  | 1  | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  |
| 0  | 1  | 1  | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  |
| 1  | 0  | 1  | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 0  |
| 1  | 1  | 0  | 0  | 0   | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 0  |
| 0  | 1  | 1  | 1  | 0   | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0  |
| 1  | 0  | 1  | 1  | 0   | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| 1  | 1  | 0  | 1  | 0   | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| 1  | 1  | 1  | 0  | 0   | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| 1  | 1  | 1  | 1  | 1   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

### Conclusions

#### Encoder



#### Decoder

