Graehme Blair Drew Hasse

**EECS 355** 

Lab 3: Sequential Divider

**Simulation Results** 

Two simulations were run. Both the 16 and 32 bit test cases from Lab 2 were used to test the sequential divider.

Numbers for the divider tests were read in from a text file in the pattern:

Dividend

Divisor

And then passed to the divider component.

| 16 bit divider simulation input:<br>12<br>4 | Output:<br>12 / 4 = 3 0    |
|---------------------------------------------|----------------------------|
| 16                                          | 16 / 2 = 8 0               |
| 2<br>1000                                   | 1000 / 0 = 1000 0 OVERFLOW |
| 0<br>12                                     | 12 / 7 = 1 5               |
| 7                                           | 25000 / 250 = 100 0        |
| 25000<br>250                                | 12 / 9 = 1 3               |
| 12<br>9                                     | 3200 / 52 = 61 28          |
| 3200                                        | 58346 / 127 = 459 53       |
| 52<br>58346                                 | 12345 / 123 = 100 45       |
| 127<br>12345<br>123                         | 9876 / 102 = 96 84         |
| 9876<br>102                                 |                            |

## Waveform output (16 bit):



| 32 bit divider simulation input: 1000000 2500 | Output:<br>1000000 / 2500 = 400 0 |
|-----------------------------------------------|-----------------------------------|
| 4598093                                       | 4598093 / 12300 = 373 10193       |
| 12300<br>1000009                              | 1000009 / 4598 = 217 2243         |
| 4598<br>3200000                               | 3200000 / 24501 = 130 14870       |
| 24501                                         | 3490000 / 9 = 387777 7            |
| 3490000<br>9                                  | 123456 / 9876 = 12 4944           |
| 123456<br>9876                                | 4543245 / 6475 = 701 4270         |
| 4543245                                       | 63665742 / 567 = 112285 147       |
| 6475<br>63665742                              | 27538530 / 9852 = 2795 2190       |
| 567<br>27538530                               | 6575097 / 45 = 146113 12          |
| 9852<br>6575097                               |                                   |
| 45                                            |                                   |

## Waveform output (32 bit):



## Design:

The divider is implemented using one comparator. When the start button is pressed, the values dividend and divisor are passed to the comparator, the quotient is reset to zero, and the calculation begins. At each rising edge of the clock, remainder from the previous step is fed into the top bits of DINL and the next bit of the dividend is fed into the least significant bit of DINL. DINR is always set to the divisor. At the falling edge of the clock, the remainder is updated to DOUT from the comparator and the quotient bit is set in a variable holding the quotient during the calculation. A counter keeps track of the number of cycles, and after DIVIDEND\_WIDTH cycles, the quotient output is displayed.