## Digital Systems Design ECSE 323 Lab Report 116-4 Encoder

Jaeho Lee Andrew Lowther



## 1 Circuit Explanation

A 16:4 Encoder circuit has been created for this lab. The encoder circuit has a 16-bit input bus, a 4-bit output bus, and a single bit error output port. The purpose of the encoder is to get the number of low input bits from 16-bit input until the first high bit appears (i.e. the index of the lowest high input). The 4-bit output represents the number of low inputs until the first high input named, and is named CODE. The one single bit output is ERROR which is high when none of the input bit is high. Since we have 16-bit inputs, there are  $2^{16} = 65534$  possible combinations and CODE is in range of 0 to 15.

## 2 Circuit Validation

Two scripts were written to test the circuit. The first covered each of the simple cases:



With a single high bit:



The error case, where all bits were low, and then a set of more complex cases, where there were two high bits:



Because the code for the circuit should function regardless of the number of extra high bits, testing with one extra was assumed to cover all such cases. To double check, an exhaustive case was written, which generated all possible outputs. This was also run, and various points were inspected. Those were the cases from the limited test (to ensure matching results), other points, such as having all 1's except the 16th bit, and all 0's but the 16th bit, were checked to verify that the circuit was correctly handling the multiple-high cases.



Fall 2016.

|               | P                                               | 0                                                      | N                                             | 2                                                    | 2                                                           | 7                                  | 7                                          | Marks    |                                                        |                                                           |      |
|---------------|-------------------------------------------------|--------------------------------------------------------|-----------------------------------------------|------------------------------------------------------|-------------------------------------------------------------|------------------------------------|--------------------------------------------|----------|--------------------------------------------------------|-----------------------------------------------------------|------|
|               | 7.                                              | 6.                                                     | 5.                                            | 4.                                                   | $\omega$                                                    | 2.                                 |                                            |          | Grou                                                   | Grou                                                      | Grou |
|               | Simulation results for the 16:4 encoder circuit | Simulation Testbench VHDL for the 16:4 encoder circuit | VHDL description for the 16:4 encoder circuit | Complete simulation results for the 6-bit comparator | Initial partial simulation results for the 6-bit comparator | VHDL file for the 6-bit comparator | Schematic diagram for the 6-bit comparator | >000     | Group Member Name: ANDREW LOW THEK Student Number: 206 | Group Member Name: 1 ATHO LEE . Student Number: 260677799 |      |
| TA Signatures |                                                 | 1,041                                                  |                                               |                                                      |                                                             | <i>&gt;</i>                        |                                            | X 258377 |                                                        | 0683759                                                   |      |

attempt was made. A grade of 0 will be given for parts that were not done at all, or for which everything is done correctly. A grade of 1 will be given if there are significant problems, but an grade sheet. Grades for each part will be either 0, 1, or 2. A mark of 2 will be given if there is no TA signature. Each part should be demonstrated to one of the TAs who will then give a grade and sign the