### UNIVERSITY OF CALIFORNIA, DAVIS Department of Electrical and Computer Engineering

## **EEC 18**

# **DIGITAL SYSTEMS I**

Fall 2021

#### LAB 5: COUNTER DESIGN

**Objective:** Design and build a counter using flip-flops, gates, and a specified counting sequence. Derive the flip-flop input equations using a state table and K-maps

### **Preparation (Pre-lab)**

- Do the *complete* paper design for the counter specified in Design I. Your paper design must include the following:
  - State transition table for the counter
  - K-maps for each of the flip-flop input equations.
  - Minimized sum of products (SoP) equation for each flip-flop input signal.

#### Description

In this lab, you will design a *unique* counter that implements the state diagram shown in the figure below. Your individualized count sequence is at the end of this document. The count values  $X_1 - X_6$  shown in the figure are some sequence of the numbers 1 - 6, with each number used only once. This circuit will simulate rolling a six-sided die.



Figure 1. Counter State Diagram

The counter has an input Rb, which stands for "Roll button". The counter counts as long as Rb = 1, but when Rb = 0 the counter maintains the last count value.

There is one other possible state in a 3-bit counter design. For example if  $X_1$  to  $X_6$  correspond to state bits 001 to 110 and the reset state corresponds to state bits 000, the unused state has state bits 111. It is possible that the state machine could power-up in this state. So you must guarantee that the state machine does not remain stuck in this state, even when the reset switch is not pressed. Thus, the next state after the unused state must be to one of the states in the count sequence,  $X_1$  to  $X_6$ , or the reset state.

## Design I. Moore Machine with the State Bits as the Outputs

Design the counter as a Moore machine where the state bits serve as the counter's outputs.

- a) Draw a state transition table and derive the input equations for implementing the counter using D flip-flops and logic gates.
- b) Enter your design in Quartus. Use the 7474 or the DFF component for the D flip-flops, the 7447 component for the seven-segment display logic, INPUT and OUTPUT components and basic logic gates (AND, OR, NOT, etc.)

Use pushbutton switches for Rb and for Reset. Display the output on HEX0. This circuit should be clocked by the 50 MHz clock signal, MAX10\_CLK1\_50.

c) Verify your design by simulating in ModelSim. Print a copy of your simulation waveforms for one complete cycle for your lab report. Set the radix to hex for the seven-segment output signal. <u>Have your TA verify your simulation</u>.

Simulate with a clock period of 20 ns and run the simulation for 100 ns each step.

# **Design II. Mealy Machine**

Design the counter as a Mealy machine. Do a <u>complete</u> paper design. However, you do not need to enter your design as a Quartus schematic or simulate your design. Compare the number of gates required for the Mealy machine with the number required for the Moore machine in Design I.

## **Implementation of Design I**

Once your simulation for Design I works, download your design to the DE10-Lite board and verify that your circuit works. **Don't forget to import the pin assignments!!** The output will change too fast to observe the sequence while the counter is counting, but you should observe that the counter stops on numbers 1 to 6 with about equal probability. If the die seems to be 'unfair', check your simulation and your circuit carefully. Another debugging technique is to test your circuit with a slow clock so you can see the count sequence. Have your TA verify your working circuit.

# Lab Report

Use the format specified in the "Lab Report Requirements" document available on the class web page. Include the following items in your lab report:

- □ Lab cover sheet with TA verification for circuit simulation and performance
- Graded pre-lab
- □ Logic design documentation (truth table, K maps, logic equations) for both designs
- Quartus schematics for Design I
- Decide ModelSim simulation waveforms for Design I

Answer the following questions in your Lab Report:

Q1: Compare Design I and Design II of the sequential circuit. Describe any advantages or disadvantages of the Moore design for this circuit.

**Q2**: A third design for the counter circuit might use a Moore machine where the state bits were not used as the outputs. For example, the state bits might be the binary count sequence 0 - 6. How would this design compare with Designs I and II (assuming your assigned count was not the straight binary count sequence 1 to 6)? Which design is likely to require the fewest gates? Justify your answer.

# Grading

| Prelab                                                       | 25 points   |
|--------------------------------------------------------------|-------------|
| Lab Verification (Simulation)                                | 20 points   |
| Lab Verification (Hardware)                                  | 20 points   |
| Lab Report                                                   | 35 points   |
| • Mealy machine paper design (Design II)                     | 10 points   |
| • Question Q1                                                | 5 points    |
| • Question Q2                                                | 5 points    |
| Quartus schematic                                            | 5 points    |
| • Quartus simulation waveform for your unique count sequence | e 10 points |

Last 5

# digits of

| ulgits of |    |    |    |    |    |    |
|-----------|----|----|----|----|----|----|
| user ID   | X1 | X2 | X3 | X4 | X5 | X6 |
| 99013     | 3  | 2  | 6  | 5  | 4  | 1  |
| 88717     | 3  | 1  | 6  | 5  | 4  | 2  |
| 16690     | 2  | 3  | 6  | 5  | 4  | 1  |
| 04047     | 1  | 3  | 6  | 5  | 4  | 2  |
| 54353     | 2  | 1  | 6  | 5  | 4  | 3  |
| 20441     | 1  | 2  | 6  | 5  | 4  | 3  |
| 06253     | 4  | 2  | 6  | 5  | 3  | 1  |
| 53778     | 4  | 1  | 6  | 5  | 3  | 2  |
| 67398     | 4  | 3  | 6  | 5  | 2  | 1  |
| 10311     | 4  | 3  | 6  | 5  | 1  | 2  |
| 33155     | 4  | 1  | 6  | 5  | 2  | 3  |
| 22472     | 4  | 2  | 6  | 5  | 1  | 3  |
| 29069     | 2  | 4  | 6  | 5  | 3  | 1  |
| 40264     | 1  | 4  | 6  | 5  | 3  | 2  |
| 61677     | 3  | 4  | 6  | 5  | 2  | 1  |
| 42713     | 3  | 4  | 6  | 5  | 1  | 2  |
| 22119     | 1  | 4  | 6  | 5  | 2  | 3  |
| 81834     | 2  | 4  | 6  | 5  | 1  | 3  |
| 35679     | 2  | 1  | 6  | 5  | 3  | 4  |
| 53009     | 1  | 2  | 6  | 5  | 3  | 4  |
| 80645     | 3  | 1  | 6  | 5  | 2  | 4  |
| 63123     | 3  | 2  | 6  | 5  | 1  | 4  |
| 53193     | 1  | 3  | 6  | 5  | 2  | 4  |
| 54433     | 2  | 3  | 6  | 5  | 1  | 4  |
| 51857     | 3  | 2  | 6  | 4  | 5  | 1  |
| 62597     | 3  | 1  | 6  | 4  | 5  | 2  |
| 69124     | 2  | 3  | 6  | 4  | 5  | 1  |
| 04213     | 1  | 3  | 6  | 4  | 5  | 2  |
| 13834     | 2  | 1  | 6  | 4  | 5  | 3  |
| 73222     | 1  | 2  | 6  | 4  | 5  | 3  |
| 64257     | 4  | 2  | 6  | 3  | 5  | 1  |
| 43686     | 4  | 1  | 6  | 3  | 5  | 2  |
| 39497     | 4  | 3  | 6  | 2  | 5  | 1  |
| 68021     | 4  | 3  | 6  | 1  | 5  | 2  |
| 82301     | 4  | 1  | 6  | 2  | 5  | 3  |
| 93154     | 4  | 2  | 6  | 1  | 5  | 3  |
| 99155     | 2  | 4  | 6  | 3  | 5  | 1  |
| 40804     | 1  | 4  | 6  | 3  | 5  | 2  |
| 02475     | 3  | 4  | 6  | 2  | 5  | 1  |
| 60690     | 3  | 4  | 6  | 1  | 5  | 2  |
| 40914     | 1  | 4  | 6  | 2  | 5  | 3  |
|           |    |    |    |    |    |    |