

# 0-99 Synchronous Up/Down Counter Design Report

## 1 Overview

This design creates a decimal counter (0-99) with:

- Two seven-segment displays
- Up/down counting functionality via push buttons
- LED indicator when count reaches 99
- Synchronous operation using JK flip-flops

## 2 System Design

### 2.1 Components Required

1. 8 JK flip-flops (4 for each decimal digit)
2. 2 seven-segment displays with BCD-to-7-segment decoders
3. 2 push buttons (up/down)
4. Logic gates (AND, OR, NOT)
5. Debounce circuits for push buttons
6. LED indicator with driver
7. Clock source

### 2.2 Counter Structure

We'll implement this as two cascaded BCD (Binary Coded Decimal) counters:

- First stage: Units digit (0-9)
- Second stage: Tens digit (0-9)

## 3 Circuit Design

### 3.1 Flip-Flop Configuration

For each decimal digit (0-9), we need 4 JK flip-flops to represent values in binary:

- Units digit: FF<sub>0</sub>, FF<sub>1</sub>, FF<sub>2</sub>, FF<sub>3</sub> (representing 1, 2, 4, 8)
- Tens digit: FF<sub>4</sub>, FF<sub>5</sub>, FF<sub>6</sub>, FF<sub>7</sub> (representing 10, 20, 40, 80)

### 3.2 Clock and Control Logic

#### 3.2.1 Clock Source:

- Each push button will generate one clock pulse
- The UP and DOWN buttons will share the same clock line but affect the J/K inputs differently

#### 3.2.2 Input Logic for UP Counter:

For the units digit (0-9):

FF<sub>0</sub> :  $J_0 = 1, K_0 = 1$  (toggles with every clock)

FF<sub>1</sub> :  $J_1 = Q_0, K_1 = Q_0$  (toggles when  $Q_0 = 1$ )

FF<sub>2</sub> :  $J_2 = Q_0 \cdot Q_1, K_2 = Q_0 \cdot Q_1$  (toggles when  $Q_0 = Q_1 = 1$ )

FF<sub>3</sub> :  $J_3 = Q_0 \cdot Q_1 \cdot Q_2, K_3 = Q_0 \cdot Q_1 \cdot Q_2$  (toggles when  $Q_0 = Q_1 = Q_2 = 1$ )

For the tens digit, connect to the units digit:

- Clock = Clock AND (Units=9) AND UP for increment

#### 3.2.3 Input Logic for DOWN Counter:

For counting down, we'll need additional logic:

- FF<sub>0</sub>:  $J = 1, K = 1$  (still toggles)
- For other flip-flops, modify inputs to handle down-counting
- Clock = Clock AND (Units=0) AND DOWN for tens digit decrement

### 3.3 Overflow and Reset Logic

#### 3.3.1 Detection Logic:

- 99 detection:  $Q_7 \cdot Q_6 \cdot \overline{Q_5} \cdot \overline{Q_4} \cdot Q_3 \cdot Q_2 \cdot \overline{Q_1} \cdot \overline{Q_0}$  (1001 1001 in binary)
- 00 detection:  $\overline{Q_7} \cdot \overline{Q_6} \cdot \overline{Q_5} \cdot \overline{Q_4} \cdot \overline{Q_3} \cdot \overline{Q_2} \cdot \overline{Q_1} \cdot \overline{Q_0}$

### 3.3.2 Indicator LED:

- $\text{LED} = Q_7 \cdot Q_6 \cdot \overline{Q_5} \cdot \overline{Q_4} \cdot Q_3 \cdot Q_2 \cdot \overline{Q_1} \cdot \overline{Q_0}$  (99 in BCD: 1001 1001)

## 4 Implementation Details

### 4.1 BCD Counter Logic

Each BCD counter needs to count from 0-9 only, so we need reset logic:

- When count reaches 1010 (10 in binary), reset to 0000
- For UP counter: When a digit reaches 9 and UP is pressed, reset digit to 0 and increment next digit
- For DOWN counter: When a digit reaches 0 and DOWN is pressed, set digit to 9 and decrement next digit

### 4.2 Seven-Segment Display Interface

For each 4-bit BCD digit, connect to a BCD-to-7-segment decoder:

- Units digit: Connect FF<sub>0</sub>-FF<sub>3</sub> outputs
- Tens digit: Connect FF<sub>4</sub>-FF<sub>7</sub> outputs

### 4.3 Push Button Interface

#### 4.3.1 Debounce Circuit:

- Add RC filter and Schmitt trigger for each button
- Use edge-triggered operation to prevent multiple counts

#### 4.3.2 Direction Control:

- UP Button: Activates UP logic paths
- DOWN Button: Activates DOWN logic paths

## 5 Circuit Implementation

### 5.1 Clock Generation

Push Button → Debounce Circuit → Edge Detector → Clock Signal

## 5.2 JK Flip-Flop Connections for Units Digit (UP)

FF<sub>0</sub> : J<sub>0</sub> = 1, K<sub>0</sub> = 1  
FF<sub>1</sub> : J<sub>1</sub> = Q<sub>0</sub>, K<sub>1</sub> = Q<sub>0</sub>  
FF<sub>2</sub> : J<sub>2</sub> = Q<sub>0</sub> · Q<sub>1</sub>, K<sub>2</sub> = Q<sub>0</sub> · Q<sub>1</sub>  
FF<sub>3</sub> : J<sub>3</sub> = Q<sub>0</sub> · Q<sub>1</sub> · Q<sub>2</sub>, K<sub>3</sub> = Q<sub>0</sub> · Q<sub>1</sub> · Q<sub>2</sub>

## 5.3 JK Flip-Flop Connections for Units Digit (DOWN)

FF<sub>0</sub> : J<sub>0</sub> = 1, K<sub>0</sub> = 1  
FF<sub>1</sub> : J<sub>1</sub> =  $\overline{Q_0}$ , K<sub>1</sub> =  $\overline{Q_0}$   
FF<sub>2</sub> : J<sub>2</sub> =  $\overline{Q_0} + \overline{Q_1}$ , K<sub>2</sub> =  $\overline{Q_0} + \overline{Q_1}$   
FF<sub>3</sub> : J<sub>3</sub> =  $\overline{Q_0} + \overline{Q_1} + \overline{Q_2}$ , K<sub>3</sub> =  $\overline{Q_0} + \overline{Q_1} + \overline{Q_2}$

## 5.4 Reset Logic for Units Digit

Reset\_Units\_UP = Q<sub>3</sub> ·  $\overline{Q_2}$  ·  $\overline{Q_1}$  · Q<sub>0</sub> (When count = 1001 or 9)  
Reset\_Units\_DOWN =  $\overline{Q_3} \cdot \overline{Q_2} \cdot \overline{Q_1} \cdot \overline{Q_0}$  (When count = 0000 or 0)

## 5.5 Tens Digit Clock

Tens\_Clock\_UP = Main\_Clock AND Q<sub>3</sub> ·  $\overline{Q_2}$  ·  $\overline{Q_1}$  · Q<sub>0</sub> AND UP\_Button  
Tens\_Clock\_DOWN = Main\_Clock AND  $\overline{Q_3} \cdot \overline{Q_2} \cdot \overline{Q_1} \cdot \overline{Q_0}$  AND DOWN\_Button

## 5.6 99 Detection for LED

LED = (Q<sub>7</sub> · Q<sub>6</sub> ·  $\overline{Q_5}$  ·  $\overline{Q_4}$ ) AND (Q<sub>3</sub> · Q<sub>2</sub> ·  $\overline{Q_1}$  ·  $\overline{Q_0}$ )

## 6 Testing Procedure

1. Power up the circuit and verify all displays show "00"
2. Press the UP button repeatedly and verify counting from 00 → 01 → ... → 99
3. Confirm LED illuminates when counter reaches 99
4. Press UP button at 99 and verify counter wraps to 00
5. Press DOWN button repeatedly and verify decremental counting
6. Press DOWN button at 00 and verify counter wraps to 99

## 7 Detailed Circuit Operation

### 7.1 UP Operation

For UP counting, the circuit performs these operations:

1. When UP button is pressed, a clock pulse is generated
2. The units digit increments by 1
3. If units digit was 9, it rolls over to 0 and generates a carry pulse
4. The carry pulse increments the tens digit
5. When the counter reaches 99, the LED lights up
6. The next UP pulse rolls the counter to 00

### 7.2 DOWN Operation

For DOWN counting, the circuit performs these operations:

1. When DOWN button is pressed, a clock pulse is generated
2. The units digit decrements by 1
3. If units digit was 0, it rolls over to 9 and generates a borrow pulse
4. The borrow pulse decrements the tens digit
5. When the counter reaches 00, the next DOWN pulse rolls the counter to 99

### 7.3 Implementation Notes

1. Use synchronous design principles - all flip-flops change state based on the same clock signal
2. Add pull-down resistors to button inputs to prevent floating inputs
3. Consider adding a manual reset button to return the counter to 00
4. Ensure adequate power supply filtering to prevent erroneous triggering

Table 1: Complete Connection Table for 0-99 Up/Down Counter

| Component                         | Pin/Terminal                       | Connection Details                                                                                                                                                                                                                                                      | Notes                                                                              |
|-----------------------------------|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|
| FF <sub>0</sub>                   | Clock<br>J<br>K<br>Q<br>$\bar{Q}$  | Main Clock AND (UP OR DOWN)<br>Logic HIGH (1)<br>Logic HIGH (1)<br>Connects to J <sub>1</sub> , K <sub>1</sub> , and Seven-Segment Decoder Bit 0<br>Not used                                                                                                            | First flip-flop<br>Always set to 1<br>Always set to 1<br>LSB of Units              |
| FF <sub>1</sub>                   | Clock<br>J, K<br>Q<br>$\bar{Q}$    | Main Clock AND (UP OR DOWN)<br>UP mode: Q <sub>0</sub> , Down mode: $\bar{Q}_0$<br>Connects to Seven-Segment Decoder Bit 1, J <sub>2</sub> , K <sub>2</sub><br>Not used                                                                                                 | Multiplexed input                                                                  |
| FF <sub>2</sub>                   | Clock<br>J, K<br>Q<br>$\bar{Q}$    | Main Clock AND (UP OR DOWN)<br>UP mode: (Q <sub>0</sub> AND Q <sub>1</sub> ), Down mode: ( $\bar{Q}_0$ OR $\bar{Q}_1$ )<br>Connects to Seven-Segment Decoder Bit 2, J <sub>3</sub> , K <sub>3</sub><br>Not used                                                         | Multiplexed input                                                                  |
| FF <sub>3</sub>                   | Clock<br>J, K<br>Q<br>$\bar{Q}$    | Main Clock AND (UP OR DOWN)<br>UP mode: (Q <sub>0</sub> AND Q <sub>1</sub> AND Q <sub>2</sub> ), Down mode: ( $\bar{Q}_0$ OR $\bar{Q}_1$ OR $\bar{Q}_2$ )<br>Connects to Seven-Segment Decoder Bit 3<br>Connects to detection logic                                     | Multiplexed input<br>MSB of Units                                                  |
| FF <sub>4</sub>                   | Clock<br>J, K<br>Q<br>$\bar{Q}$    | (Q <sub>3</sub> · Q <sub>2</sub> · Q <sub>1</sub> · Q <sub>0</sub> AND UP) OR ( $\bar{Q}_3$ · Q <sub>2</sub> · Q <sub>1</sub> · Q <sub>0</sub> AND DOWN)<br>Logic HIGH (1)<br>Connects to J <sub>5</sub> , K <sub>5</sub> , and Seven-Segment Decoder Bit 0<br>Not used | Carries/Borrows<br>Always set to 1<br>LSB of Tens                                  |
| UP Mode<br>DOWN Mode              | -<br>-                             | UP Button Output<br>DOWN Button Output                                                                                                                                                                                                                                  | Sets count direction<br>Sets count direction                                       |
| Units Display<br>Tens Display     | BCD inputs<br>BCD inputs           | Q <sub>0</sub> , Q <sub>1</sub> , Q <sub>2</sub> , Q <sub>3</sub><br>Q <sub>4</sub> , Q <sub>5</sub> , Q <sub>6</sub> , Q <sub>7</sub>                                                                                                                                  | Units digit decoder<br>Tens digit decoder                                          |
| 99 Detector                       | Inputs<br>Output                   | Q <sub>7</sub> · Q <sub>6</sub> · Q <sub>5</sub> · Q <sub>4</sub> · Q <sub>3</sub> · Q <sub>2</sub> · Q <sub>1</sub> · Q <sub>0</sub><br>Connects to LED                                                                                                                | Detects 99 (1001 1001 in binary)<br>Lights when count reaches 99                   |
| UP Debounce<br>DOWN De-<br>bounce | Input<br>Output<br>Input<br>Output | UP Button<br>UP Signal<br>DOWN Button<br>DOWN Signal                                                                                                                                                                                                                    | Raw button input<br>Clean button signal<br>Raw button input<br>Clean button signal |

Continued on next page

Table 1 – *Continued from previous page*

| <b>Component</b> | <b>Pin/Terminal</b> | <b>Connection Details</b>                     | <b>Notes</b>                 |
|------------------|---------------------|-----------------------------------------------|------------------------------|
| Reset            | Input<br>Output     | Reset Button<br>Connects to all FF CLR inputs | Optional<br>Active low reset |