# Sequential Circuits

Sequential circuit can be defined as a circuit whose output depends not only on the present inputs but also on the past history of the inputs. (Stored information).





## 1. What is a Flip-flop? Write the logical symbol of Flip-flop.

A flip-flop is a bistable electronic circuit that has two stable states and can be used to store binary data (0 or 1).

- $\checkmark$  A flip-flop is a binary storage device.
- $\checkmark$  It has two stable states HIGH and LOW i.e '1' and '0'.
- $\checkmark$  It is also called bistable multivibrator.
- $\checkmark$  A flip-flop circuit has two outputs, one for the normal value and other for the complement value of the bit stored in it.

### Logic Symbol:



### 2. List the different types of Flip-flops.

- 1. RS flip-flop
- 2. JK flip-flop
- 3. Master-slave flip-flop
- 4. D- flip-flop
- 5. T- flip-flop
- 3. Explain RS Flip-flop with truth table, logic symbol and logical circuit.
- $\checkmark$  The S and R in SR flip flop means 'SET' and 'RESET' respectively.
- $\checkmark$  SR flip flop has two stable states in which it can store data in the form of either 0 (LOW) or 1 (HIGH).



Logic circuit:



Operation of a positive edge-triggered S-R flip-flop.



#### $\blacktriangleleft$  TABLE 7-2

Truth table for a positive edgetriggered S-R flip-flop.

#### Working;

- 1. When S=0 and R=0, the output does not change from its prior state or no change state.<br>2. When S=0 and R=1, the output  $Q = 0$ , and the flip-flop is in RESET state.
- 
- 3. When  $S=1$  and  $R=0$ , the output  $Q=1$ , and the flip-flop is in SET state.
- 4. When  $S=1$  and  $R=1$ , an invalid condition exists.
- 4. Explain JK Flip-flop with truth table, logic symbol and logical circuit.
- $\checkmark$  The J-K flip-flop is versatile and is a widely used type of flip-Hop.
- $\checkmark$  J-K Flip-flop has two inputs, labeled J and K (along with the CLK).
- $\checkmark$  The functioning of the J-K flip-flop is identical to that of the S-R flip-flop in the SET, RESET, and no-change conditions of operation. The difference is that the J-K flip-flop has no invalid state as does the S-R flip-flop.
- When both J and  $K = 1$ , the output changes states (toggles) on the rising clock edge.
- $\checkmark$  A J-K flip-flop connected for toggle operation is sometimes called a T flip-flop.



#### Working;

- 
- 1. When J=0 and K=0, the output does not change from its prior state or no change state.<br>2. When J=0 and K=1, the output  $Q = 0$ , and the flip-flop is in RESET state.
- 3. When **J**=1 and **K**=0, the output  $Q = 1$ , and the flip-flop is in **SET** state..
- 4. When  $J=1$  and  $K=1$  the output changes to the complement state called  $-Toggle$  or alternately blinking on-off (1-0), off-on(0-1), on-off (1-0) likewise.<br>5. What is race around condition? In which Flip-flop it is overcome.
- 

When we put  $J=1$  and  $K=1$  in  $J-K$  flip-flop, the output, Q toggles to 0 and 1 continuously; and it

becomes uncertain to predict the output. This condition is known as **Race around condition**. To overcome **race around condition** problem we should use **J**-**K** Master Slave flip-flop.

### 6. Explain J-K Master Slave Flip-flop with truth table, log symbol and logical circuit.

- $\checkmark$  A J-K Master Slave flip- flop consists of two clocked J-K flip-flops with a feedback from the output of the second flip-flop (Slave) to the input of the first (Master) flip-flop.
- $\checkmark$  When the clock is HIGH, the Master is active. The output of the Master is Set or Reset according to the state of the input. As the slave is inactive during this period, it's output remains in the previous state.
- $\checkmark$  When the clock becomes LOW, the output of the Slave flip flop changes because it becomes active during LOW clock period.

#### Logical symbol:



#### Logical circuit:



### Truth table:



## 7. Explain D-Flip-flop with truth table, logic symbol and logical circuit

- $\checkmark$  The D-flip-flop is useful when a single data bit (1 or 0) is to be stored.
- $\checkmark$  An Inverter is connected so that the R input is always the inverse of S.
- $\checkmark$  The added inverter reduces the number of inputs from two to one.

#### $\triangleright$  FIGURE 7-20

A positive edge-triggered D flip-flop formed with an S-R flip-flop and an inverter.



### Logical circuit:



#### Working:

- 1. When  $D=0$ , the output  $Q=0$ , and the flip-flop is in **RESET** state.
- 2. When  $D=1$ , the output  $Q = 1$ , and the flip-flop is in SET state.

## 8. List the applications of Flip-flop.

Flip Flops are used in the following applications:

- 1. Parallel Data Storage.
- 2. Counting.
- 3. Frequency Division
- 4. Register and Shift Register.
- 5. Latch.

## 9. What is Shift Registers? List its applications.

- $\checkmark$  A register is a digital circuit with two basic functions: data storage and data movement. It can consist of one or more flip-flops which are used to store and shift data.
- $\checkmark$  The Shift Registers consists of flip-flops that can be used for the storage and movement (transfer) of binary data in a digital system. OR
- $\checkmark$  Shift Registers are **sequential logic circuits**, capable of storage and transfer of data. They are made up of Flip Flops which are connected in such a way that the output of one flip flop could serve as the input of the other flip-flop, depending on the type of shift registers being created.

### Applications of shift register:

- $\checkmark$  Storage and movement (transfer) of binary data in a digital system.
- $\checkmark$  Shift register is used as **Parallel to serial converter**, which converts the parallel data into serial data. It is utilized at the transmitter section after Analog to Digital Converter (ADC) block.
- $\checkmark$  Shift register is used as **Serial to parallel converter**, which converts the serial data into parallel data. It is utilized at the receiver section before Digital to Analog Converter (DAC) block.
- $\checkmark$  Shift registers are also used as **counters**. Arithmetic operations
- $\checkmark$  Time delays
- $\checkmark$  Keyboard Encoder
- URAT- Universal Asynchronous Receiver Transmitter

### 10. Write the functions of shift registers and list its types

The two basic functions of shift registers are:

- 1. Data storage and
- 2. Data movement.
- $\checkmark$  The *storage capacity* of a register is the total number of bits (1s and 0s) of digital data it can retain. Each stage (flip-flop) a shift register represents one bit of storage capacity; therefore, the number of stages in register determines its storage capacity.
- $\checkmark$  The shift capability of a register permits the movement of data from stage to stage within the register or into or out of the register upon application of clock pulses.
- $\checkmark$  Figure 8-2 illustrates the types of data movement in shift registers. The block represents any arbitrary 4-bit register, and the arrows indicate the direction of data movement.



- 1. Serial-In/Serial-Out shift register (SISO)
- 2. Serial-In/Parallel-Out shift register (SIPO)
- 3. Parallel-In/Serial-Out shift register (PISO)
- 4. Parallel-In/Parallel-Out shift register (PIPO)

#### 11. Explain the working of 4-bit serial in serial out (SISO) with logical circuit and truth table.

- $\checkmark$  The serial in/serial out shift register accept data serially -that is, one bit at a time on a single line. It produces the stored information on its output also in serial form.
- $\checkmark$  A basic 4-bit SISO shift register can be constructed using 4 D flip-flops, as shown in the below figure 8.3.
- $\checkmark$  The output of the one stage is connected to the input of the next stage and a common clock is used to activate all the flip-flops at a time. Input is applied at the first flip -flop (FF0) and output is taken at the last flip flop (FF3).



FIGURE 8-3 Serial in/serial out shift register.

Assuming for the 4-bit shift register above, we want to send the word "1010". After clearing the shift register, the output of all the flip flops becomes 0, so during the first clock cycle as we apply this data (1010) serially, the outputs of the flip flops look like the table below.

| <b>Clock Pulse</b>          | <b>Serial IN</b><br>at<br>D of FF0 | FF <sub>0</sub><br>$(Q_0)$ | FF1<br>$(Q_1)$   | FF2<br>(Q <sub>2</sub> ) | FF3<br>$(Q_3)$ | Serial OUT at Q3 of FF3                                                                             |
|-----------------------------|------------------------------------|----------------------------|------------------|--------------------------|----------------|-----------------------------------------------------------------------------------------------------|
| Register<br>initially Clear |                                    | $\theta$                   | $\theta$         | $\boldsymbol{0}$         | $\mathbf{0}$   | Ξ.                                                                                                  |
| After<br>CLK1<br>pulse      | $\mathbf{0}$<br>(LSB)              | $\bf{0}$                   | $\theta$         | $\boldsymbol{0}$         | $\mathbf{0}$   |                                                                                                     |
| After CLK2<br>pulse         | 1                                  | 1                          | $\boldsymbol{0}$ | $\boldsymbol{0}$         | $\mathbf{0}$   |                                                                                                     |
| After CLK3<br>pulse         | $\mathbf{0}$                       | $\bf{0}$                   | $\mathbf{1}$     | $\bf{0}$                 | $\mathbf{0}$   | $\overline{\phantom{a}}$                                                                            |
| After CLK4<br>pulse         | (MSB)                              | 1                          | $\boldsymbol{0}$ | 1                        | $\bf{0}$       | After CLK4, the 4 bit number 1010 is<br>completely stored in register. 1 <sup>st</sup> data bit out |
| After CLK5<br>pulse         |                                    | $\mathbf{0}$               | $\mathbf{1}$     | $\bf{0}$                 | $\mathbf{1}$   | $2nd$ data bit out (1)                                                                              |
| After CLK6<br>pulse         |                                    | $\mathbf{0}$               | $\theta$         | 1                        | $\bf{0}$       | $3rd$ data bit out (0)                                                                              |
| After CLK7<br>pulse         |                                    | $\mathbf{0}$               | $\theta$         | $\overline{0}$           | $\mathbf{1}$   | $4th$ data bit out (1)                                                                              |
| After CLK8<br>pulse         | $\overline{a}$                     | $\mathbf{0}$               | $\boldsymbol{0}$ | $\boldsymbol{0}$         | $\overline{0}$ | After CLK8, register is Clear                                                                       |

Anil Kumar K, Sr. Lecturer, Dept. of CSE, GPT Bagepalli Page 9

#### 12. Explain the working of 4-bit serial in parallel out (SIPO) with logical circuit and truth table.

- $\checkmark$  The serial-in parallel out shift register accepts data serially (LSB first) that is, one bit at a time on a single line. It produces the stored information on its output simultaneously in parallel form.
- $\checkmark$  A basic 4-bit SIPO shift register can be constructed using 4 D flip-flops, as shown in the below figure 8.6. The output of the one stage is connected to the input of the next stage and a common clock is used to activate all the flip lops at a time.
- $\checkmark$  Input is applied at the flip flops (FF0) and output is taken at the outputs of all the flips at a time represented as  $Q_0$ ,  $Q_1$ ,  $Q_2$  and  $Q_3$  ( $Q_0$ -MSB and  $Q_3$ -LSB).



FIGURE 8-6 A serial in/parallel out shift register.



- 13. Explain the working of 4-bit parallel in serial out (PISO) with logical circuit and truth table.
- $\checkmark$  The Parallel-In Serial-Out (PISO) shift register accepts data in parallel form -that is, all bits at a time on a multiple lines.
- $\checkmark$  It produces the stored information on its output in serial form as illustrated in the below figure 8.10.



(c) Parallel in/serial out



Figure 8–10 A 4-bit parallel in/serial out shift register.

- $\checkmark$  A basic 4-bit PISO shift register can be constructed using 4 D flip flops as shown in above figure.
- $\checkmark$  The four data input lines D<sub>0</sub>, D<sub>1</sub>, D<sub>2</sub> and D<sub>3</sub> and *SHIFT/LOAD* input, which allows four bits of data to load in parallel into the register.
- $\checkmark$  When  $SHIFT/LOAD$  is LOW, gates G<sub>1</sub>, G<sub>2</sub>, G3 and G<sub>4</sub> are enabled, allowing each data bit to be applied to the D input of its respective flip-flop.
- $\checkmark$  When a clock pulse is applied, the data is loaded and stored in flip-flop simultaneously.
- $\checkmark$  When  $SHIFT/LOAD$  is HIGH, gates G<sub>5</sub>, G<sub>6</sub> and G<sub>7</sub> are enabled, allowing the data bits to shift right from one flip-flop to the next flip-flop.
- $\checkmark$  The OR gates allow either the normal shifting operation or the parallel data-entry operation, depending on which AND gates are enabled by the level on the  $SHIFT/LOAD$  input.
- $\checkmark$  Notice that FF0 has a single AND to disable the parallel input, D0. It does not require an AND/OR arrangement because there is no serial data in.



# 14. Explain the working of 4-bit parallel in parallel out (PIPO) with logical circuit and truth table.

- $\checkmark$  In a parallel-in, parallel-out (PIPO) shift register, the data is entered into the register in parallel form, and also the data is taken out of the register in parallel form.
- $\checkmark$  A basic 4-bit PIPO shift register can be constructed using 4 D flip-flops, as shown in the below figure 8.14.
- $\checkmark$  A common clock is used to activate all the flip-flops at a time.
- $\checkmark$  Data is applied to the D input terminals of the FF's. When a clock pulse is applied, at the positive going edge of the pulse, the D inputs are shifted into the Q outputs of the FFs. The register now stores the data. The stored data is available instantaneously for shifting out in parallel form.
- $\checkmark$  The simultaneous entry of all data bits, the bits appear on the parallel outputs.



E 8-14 A parallel in/parallel out register.



## 15. Define Counter. Write its applications.

The counter is a digital sequential logic circuit in which a group of flip-flops are connected in cascade.

The basic function of the counter is to count the number of input clock pulses applied. OR

Counter is a register which counts the sequence in binary form.

Applications of counter

- 1. Digital clock
- 2. Automobile parking control
- 3. Parallel to serial data conversion (multiplexing)
- 4. Traffic Signal Control.
- 5. A/D Converters
- 6. Frequency Meters/Counters
- 7. Signal Generators
- 8. Microprocessors

### 16. Compare Asynchronous and Synchronous counter.



# Asynchronous counters

- $\checkmark$  The term *asynchronous* refers to events that do not have a fixed time relationship with each other.
- $\checkmark$  An asynchronous counter is one in which the flip-flops (FF) within the counter do not change states at exactly the same time because they do not have a common clock pulse.
- $\checkmark$  Asynchronous counters commonly called **ripple counters**, the first flip-flop is clocked by the external clock pulse and then each successive flip-flop is clocked by the output of the preceding flip-flop.

## A 2-Bit Asynchronous Binary Counter



### Fig1-1 2-bit asynchronous counter

- $\checkmark$  Fig1-1 shows a 2-bit counter connected for asynchronous operation.
- $\checkmark$  The clock (CLK) is applied to the clock input (C) of only the first flop-flop, FF0, which is always the least significant bit (LSB).
- $\checkmark$  The second flip-flop, FF1, is triggered by the  $\bar{Q}_0$  out-put of FF0.
- $\checkmark$  FF0 changes state at the positive-going edge of each clock pulse. But FF1 changes only when triggered by a positive-going transition of the  $\bar{Q}_0$  output of FF0. Because of the inherent propagation delay tie through a flip-flop, a transition of the input clock pulse (CLK) and a transition of the  $\mathbf{\bar{Q}}_0$  output of FF0 can never occur at exactly the same time. Therefore, the two flip-flops are never simultaneously triggered, so the counter operation is asynchronous.





Anil Kumar K, Sr. Lecturer, Dept. of CSE, GPT Bagepalli Page 15

## The Timing Diagram

- $\checkmark$  Applying 4 clock pulses to FF0, Both flip-flops are connected for toggle operation (J=1, K=1) and initially RESET (Q LOW).
- $\checkmark$  The positive-going edge of CLK1 (clock pulse1) causes the  $Q_0$  output of FF0 to go HIGH. At the same time the  $\overline{Q_0}$  output goes LOW, but it has no effect on FF1 because a positive-going transition must occur to trigger the flip-flop.
- After the leading edge of CLK1,  $Q_0=1$  &  $Q_1=0$ . The positive-going edge of CLK2 causes  $Q_0$  to go LOW.  $\overline{Q_0}$  goes HIGH and triggers FF1, causing Q1 to go HIGH.
- After the leading edge of CLK2,  $Q_0=0$  &  $Q_1=1$ . The positive-going edge of CLK3 causes  $Q_0$  to go HIGH again. Output  $\overline{Q_0}$  goes LOW and has no effect on FF1.
- $\checkmark$  Thus, after the leading edge of CLK3,  $\checkmark$ Q<sub>0</sub>=1 & Q<sub>1</sub>=1. The positive-going edge of CLK4 causes Q<sub>0</sub> to go LOW, while  $\overline{Q_0}$  goes HIGH and triggers FF1, causing  $Q_1$  to go LOW.
- After the leading edge of CLK4,  $Q_0=0$  &  $Q_1=1$ . The 2-bit counter exhibits four different states, as you would expect with two flip-flops  $(2^2 = 4)$ .



Fig 1-2 Timing diagram for the counter of Fig1-1

The fourth pulse it recycles to its original state  $(Q_0=0, Q_1=0)$ . The term recycles; it refers to the transition of the counter from its final state back to its original state.

# A 3-Bit Asynchronous Binary Counter

| <b>CLOCK PULSE</b> | $\boldsymbol{Q}_{2}$ |          | $\bm{Q}_{0}$ |
|--------------------|----------------------|----------|--------------|
| Initially          | $\theta$             | O        | Ü            |
|                    | $\theta$             | $\theta$ |              |
| $\overline{2}$     | $\overline{0}$       |          | 0            |
| 3                  | $\mathbf 0$          |          | l            |
| 4                  | ı                    | 0        | 0            |
| 5                  | l                    | $\theta$ |              |
| 6                  |                      | 1        | 0            |
| 7                  |                      | I        |              |
| 8 (recycles)       | 0                    | 0        | 0            |

Table1-2 State sequence for a 3-bit binary counter



Fig 1-3 Three-bit asynchronous binary counter and its timing diagram for one cycle

### 16. Explain 4-bit asynchronous ripple counter.

- $\checkmark$  In 4-bit ripple counter, n value is 4 so, 4 JK flip flops are used and the counter can count up to 16  $(2<sup>4</sup>)$  pulses.
- $\checkmark$  Fig1-1 shows a 4-bit counter connected for asynchronous operation.
- $\checkmark$  Notice that the clock (CLK) is applied to the clock input (C) of only the first flop-flop, FF0, which is always the least significant bit (LSB).
- $\checkmark$  The second flip-flop, FF1, is triggered by the Q0 out-put of FF0.
- $\checkmark$  FF0 changes state at the negative-going edge of each clock pulse.
- $\checkmark$  But FF1 changes only when triggered by a positive-going transition of the Q0 output of FF0. Because of the inherent propagation delay tie through a flip-flop, a transition of the input clock pulse (CLK) and a transition of the Q0 output of FF0 can never occur at exactly the same time. Therefore, the two flip-flops are never simultaneously triggered, so the counter operation is asynchronous.

# 4-Bit Asynchronous counter



Fig1-1 a 4-bit counter





#### Asynchronous Decade Counters

- $\checkmark$  The modulus is the number of unique states through which the counter will sequence. The maximum possible number of states of a counter is  $2<sup>n</sup>$  where n is the number of flip-flops.
- $\checkmark$  Counters can be designed to have a number of states in their sequence that is less than the maximum of  $2<sup>n</sup>$ . This type of sequence is called a truncated sequence. One common modulus for counters with truncated sequences is 10 (Modules10).
- $\checkmark$  A decade counter with a count sequence of zero (0000) through 9 (1001) is a BCD decade counter because its 10-state sequence produces the BCD code. To obtain a truncated sequence, it is necessary to force the counter to recycle before going through all of its possible states. A decade counter requires 4 flip-flops. One way to make the counter recycle after the count of 9 (1001) is to decode count 10 (1010) with a NAND gate and connect the output of the NAND gate to the clear (CLR) inputs of the flip-flops, as shown in Fig1-6(a).

Partial Decoding: in Fig1-6(a) only Q1 & Q3 are connected to the NAND gate inputs. This arrangement is an example of partial decoding, in which the two unique states  $(Q_1=1 \& Q_3=1)$  are sufficient to decode the count of 10 because none of the other states (0 through 9) have both  $Q_1 \& Q_3$  HIGH at the same time.



| Clock Pulse   | Q <sub>3</sub> | Q <sub>2</sub> | Q1 | Q <sub>0</sub> |
|---------------|----------------|----------------|----|----------------|
| Initially     | 0              | 0              | 0  | 0              |
|               | 0              | 0              | 0  |                |
| 2             | 0              | $\bf{0}$       |    | 0              |
| 3             | 0              | 0              | 1  |                |
|               | 0              | 1              | 0  | 0              |
| 5             | 0              | 1              | 0  |                |
| 6             | 0              |                |    | 0              |
|               | 0              | 1              | 1  |                |
| 8             | 1              | 0              | 0  | 0              |
| 9             | 1              | 0              | 0  |                |
| 10 (recycles) | 0              | 0              | 0  | 0              |

Fig 1-6 an asynchronously clocked decade counter with asynchronous recycling.

# Synchronous Counters

- $\checkmark$  In synchronous counters, the clock input is connected to all of the flip-flops so that they are clocked simultaneously.
- $\checkmark$  The term synchronous refers to events that have a fixed time relationship with each other
- $\checkmark$  J-K flip-flops are used to illustrate most synchronous counters.

# A 2-Bit Synchronous Binary Counter





- $\checkmark$  First, when the positive edge of the first clock pulse is applied, FF0 will toggle and  $Q_0$  will therefore go HIGH. When FF1at the positive-going edge of CLK1 inputs J1 & K1 are both LOW because Q0 has not yet gone HIGH. So,  $J = 0 \& K = 1$ . This is a no-change condition, and therefore FF1 does not change state.(*fig1-9a*).
- $\checkmark$  When the leading edge of CLK2 occurs, FF0 will toggle and  $Q_0$  will go LOW and Q1 goes HIGH. Thus, after CLK2,  $Q_0=0$  &  $Q_1=1$  (Fig1-9b).
- $\checkmark$  When the leading edge of CLK3 occurs, FF0 again toggles to the SET state (Q<sub>0</sub> = 1), and FF1 remains SET (Q<sub>1</sub>=1. After this triggering edge, Q<sub>0</sub> =1 & Q<sub>1</sub> =1 (Fig1-9c). At the leading edge of CLK4,  $Q_0 \& Q_1$  go LOW (Fig1-9d).



Fig 1-9 timing details for the1-bit synchronous counter operation



Fig 1-10 complete timing diagram for the counter

# A 3-Bit Synchronous Binary Counter

In the 3-bit synchronous counter, we have used three j-k flip-flops. As in the diagram, The J and K inputs of FF0 are connected to HIGH. The inputs J and K of FF1 are connected to the output of FF0, and the J and K inputs of FF2 are connected to the output of an AND gate, which is fed by the outputs of FF0 and FF1.



Fig1-11 3-bit synchronous counter

| <b>Clock Pulse</b> | $\mathcal Q_2$ | $\boldsymbol{\varrho}_\mathbf{1}$ | $\boldsymbol{\varrho}_\mathbf{0}$ |
|--------------------|----------------|-----------------------------------|-----------------------------------|
| <b>Initially</b>   |                |                                   |                                   |
|                    |                |                                   |                                   |
| 2                  |                |                                   |                                   |
| 3                  |                |                                   |                                   |
|                    |                |                                   |                                   |
| 5                  |                |                                   |                                   |
| 6                  |                |                                   |                                   |
|                    |                |                                   |                                   |
| 8 (recycles)       |                |                                   |                                   |

Table1-3 Binary state sequence



### 17. Explain 3-bit synchronous up/down counter.

- $\checkmark$  An up/down (bidirectional) counter is one that is capable of progressing in either direction through a certain sequence.
- $\checkmark$  A synchronous up-down counter has an **up-down** control input. It is used to control the direction of the counter through a certain sequence.



Figure 3.6 A basic 3-bit up/down synchronous counter.



Up/Down sequence for a 3-bit binary counter.

An examination of  $Q_0$  for both the up and down sequences shows that FF0 toggles on each clock pulse.

Thus, the  $J_0$  and  $K_0$  inputs of FF0 are

 $J_0 = K_0 = 1$ 

For the up sequence,  $Q_1$  changes state on the next clock pulse when  $Q_0 = 1$ .

For the down sequence,  $Q_1$  changes on the next clock pulse when  $Q_0 = 0$ .

Thus, the  $J_1$  and  $K_1$  inputs of FF1 must equal 1 under the conditions expressed by the following equation:

$$
J_1 = K_1 = (Q_0 \cdot \text{UP}) + (\overline{Q}_0 \cdot \text{DOWN})
$$

For the up sequence,  $Q_2$  changes state on the next clock pulse when  $Q_0 = Q_1 = 1$ .

For the down sequence,  $Q_2$  changes on the next clock pulse when  $Q_0 = Q_1 = 0$ .

Thus, the  $J_2$  and  $K_2$  inputs of FF2 must equal 1 under the conditions expressed by the following equation:

$$
J_2 = K_2 = (Q_0 \cdot Q_1 \cdot \text{UP}) + (\overline{Q}_0 \cdot \overline{Q}_1 \cdot \text{DOWN})
$$

Each of the conditions for the  $J$  and  $K$  inputs of each flip-flop produces a toggle at the appropriate point in the counter sequence.

Figure 3.6 shows a basic implementation of a 3-bit up/down binary counter using the logic equations just developed for the  $J$  and  $K$  inputs of each flip-flop.

Notice that the

```
UP/\overline{DOWN} control input is HIGH for UP and LOW for DOWN.
```


Figure 3.6 A basic 3-bit up/down synchronous counter.



A 4-Bit Synchronous Binary Counter





Fig1-13 a 4-bit synchronous binary counter and timing diagram. Points where the AND gate outputs are HIGH are indicated by the shaded areas



Example: 4-bit synchronous up-down counter







