

# Subject Name Solutions

4321102 – Summer 2024

Semester 1 Study Material

*Detailed Solutions and Explanations*

## Question 1(a) [3 marks]

Convert:  $(110101)_2 = (\underline{\hspace{2cm}})_10 = (\underline{\hspace{2cm}})_8 = (\underline{\hspace{2cm}})_16$

### Solution

Step-by-step conversion of  $(110101)_2$  :

| Binary $(110101)_2$                                                                                       | Decimal                                       | Octal                                                   | Hexadecimal                                                  |
|-----------------------------------------------------------------------------------------------------------|-----------------------------------------------|---------------------------------------------------------|--------------------------------------------------------------|
| $1 \times 2^5 + 1 \times 2^4 + 0 \times 2^3 + 1 \times 2^2 + 0 \times 2^1 + 1 \times 2^0$<br>$(110101)_2$ | $32 + 16 + 0 + 4 + 0 + 1 = 53$<br>$(53)_{10}$ | $6 \times 8^1 + 5 \times 8^0 = 48 + 5 = 53$<br>$(65)_8$ | $3 \times 16^1 + 5 \times 16^0 = 48 + 5 = 53$<br>$(35)_{16}$ |

### Mnemonic

“Binary Digits Out Here” (BDOH) for Binaryconversion.

## Question 1(b) [4 marks]

\*\*Perform: (i)  $(11101101)_2 + (10101000)_2$  (ii)  $(11011)_2 * (1010)_2$  \*\*

### Solution

Table for binary addition and multiplication:

| (i) Binary Addition                                                       | (ii) Binary Multiplication                                                                               |
|---------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|
| $\begin{array}{r} 11101101 \\ + 10101000 \\ \hline 110010101 \end{array}$ | $\begin{array}{r} \times 1010 \\ \hline 11011 \\ 00000 \\ 00000 \\ 11011 \\ \hline 11101110 \end{array}$ |

### Decimal verification:

- 1.  $(11101101)_2 = 237, (10101000)_2 = 168, Sum = 405 = (110010101)_2$
- 1.  $(11011)_2 = 27, (1010)_2 = 10, Product = 270 = (11101110)_2$

### Mnemonic

“Carry Up Makes Sum” for addition and “Shift Left Add Product” for multiplication.

## Question 1(c) [7 marks]

(i) Convert:  $(48)_{10} = (\underline{\hspace{2cm}})_2 = (\underline{\hspace{2cm}})_8 = (\underline{\hspace{2cm}})_{16}$

## Question 1(c) OR [7 marks]

Explain Codes: ASCII, BCD, Gray

## Solution

### Table of Common Digital Codes:

| Code                                                              | Description                                                                              | Example                     |
|-------------------------------------------------------------------|------------------------------------------------------------------------------------------|-----------------------------|
| <b>ASCII (American Standard Code for Information Interchange)</b> | 7-bit code representing 128 characters including alphabets, numbers, and special symbols | $A = 65 (1000001)_2$        |
| <b>BCD (Binary Coded Decimal)</b>                                 | Represents each decimal digit (0-9) using 4 bits                                         | $42 = 0100\ 0010$           |
| <b>Gray Code</b>                                                  | Binary code where adjacent numbers differ by only one bit                                | $(0,1,3,2) = (00,01,11,10)$ |

### Diagram: Gray Code Generation:

```
flowchart LR
    A["Binary Code"] --> B["Gray Code"]
    B --> C["MSB remains same"]
    C --> D["Each bit XORed with previous"]
    D --> E["Binary: 0011"]
```

## Mnemonic

“Always Binary Generates” - first letter of each code (ASCII, BCD, Gray).

## Question 2(a) [3 marks]

Simplify using Boolean Algebra:  $Y = A B + A' B + A' B' + A B'$

## Solution

### Step-by-step simplification:

| Step                            | Expression         | Boolean Law      |
|---------------------------------|--------------------|------------------|
| $Y = A B + A' B + A' B' + A B'$ | Initial expression | -                |
| $Y = A(B + B') + A'(B + B')$    | Factoring          | Distributive law |
| $Y = A(1) + A'(1)$              | Complement law     | $B + B' = 1$     |
| $Y = A + A'$                    | Simplification     | -                |
| $Y = 1$                         | Complement law     | $A + A' = 1$     |

## Mnemonic

“Factor, Simplify, Finish” for Boolean simplification steps.

## Question 2(b) [4 marks]

Simplify the following Boolean function using K-map:  $f(A,B,C,D) = \Sigma m (0,3,4,6,8,11,12)$

## Solution

### K-map Solution:

| AB |    |    |    |    |  |
|----|----|----|----|----|--|
| CD | 00 | 01 | 11 | 10 |  |
| 00 | 1  | 0  | 0  | 1  |  |
| 01 | 0  | 0  | 0  | 1  |  |
| 11 | 0  | 1  | 0  | 0  |  |
| 10 | 0  | 0  | 1  | 0  |  |

### Grouping:

- Group 1:  $m(0,8) = A'C'D'$
- Group 2:  $m(4,12) = BD'$
- Group 3:  $m(3,11) = CD$
- Group 4:  $m(6) = A'B'CD'$

**Simplified expression:**  $f(A,B,C,D) = A'C'D' + BD' + CD + A'B'CD'$

### Mnemonic

“Group Powers Of Two” for K-map grouping strategy.

## Question 2(c) [7 marks]

Explain NOR gate as a universal gate with neat diagrams.

### Solution

**NOR as Universal Gate:**

| Function        | Implementation using NOR | Truth Table                     |
|-----------------|--------------------------|---------------------------------|
| <b>NOT Gate</b> |                          | A<br>0<br>1                     |
| <b>AND Gate</b> |                          | A B<br>0 0<br>0 1<br>1 0<br>1 1 |
| <b>OR Gate</b>  |                          | A B<br>0 0<br>0 1<br>1 0<br>1 1 |

**Diagram: NOR Implementation:**

```
flowchart TD
    A["NOT: A {-{-} A}"]
    B["AND: A {-{-}1{-{-}}|}
        | 1{-{-}} A•B"]
    C["OR: A {-{-}1{-{-}}|}
        | 1{-{-}} A+B"]
    B --> C
```

### Mnemonic

“NOT AND OR, NOR does more” for remembering NOR gate implementations.

## Question 2(a) OR [3 marks]

Draw logic circuit for Boolean expression:  $Y = (A + B') \cdot (A' + B') \cdot (B + C)$

### Solution

**Logic Circuit Implementation:**

```
flowchart TD
    A["A"] --> D["OR"]
    B["B"] --> D
    D --> G["AND"]
    B --> G
```

```

A1["A{}"] {-}{-} E["OR"]
B1["B{}"] {-}{-} E}
E {-}{-} G}
B2["B{}"] {-}{-} F["OR"]
C["C{}"] {-}{-} F}
F {-}{-} G}
G {-}{-} Y["Y"]

```

#### Truth Table Verification:

- Term 1:  $(A + B')$
- Term 2:  $(A' + B)$
- Term 3:  $(B + C)$
- Output:  $Y = \text{Term1} \bullet \text{Term2} \bullet \text{Term3}$

#### Mnemonic

“Each Term Separately” for breaking complex expressions.

### Question 2(b) OR [4 marks]

State De-Morgan’s theorems and prove it.

#### Solution

#### De-Morgan’s Theorems and Proof:

| Theorem          | Statement                  | Proof by Truth Table            |
|------------------|----------------------------|---------------------------------|
| <b>Theorem 1</b> | $(A \bullet B)' = A' + B'$ | A B<br>0 0<br>0 1<br>1 0<br>1 1 |
| <b>Theorem 2</b> | $(A+B)' = A' \bullet B'$   | A B<br>0 0<br>0 1<br>1 0<br>1 1 |

#### Diagram: De-Morgan’s Law Visualization:

```

flowchart TB
    A["(A•B){ = A+B}"] {-}{-} B["Invert Operation  
AND OR  
Invert Variables"]
    C["(A+B){ = A•B}"] {-}{-} D["Invert Operation  
OR AND  
Invert Variables"]

```

#### Mnemonic

“Break BAR, Change Operation, Invert Inputs” for applying De-Morgan’s law.

### Question 2(c) OR [7 marks]

Explain all the Logic Gates with the help of Symbol, Truth table and equation.

## Solution

Logic Gates Summary:

| Gate        | Symbol | Truth Table                   | Equation             | Description |
|-------------|--------|-------------------------------|----------------------|-------------|
| <b>AND</b>  | A B    | Y<br>0 0<br>0 1<br>1 0<br>1 1 | $Y = A \bullet B$    |             |
| <b>OR</b>   | A B    | Y<br>0 0<br>0 1<br>1 0<br>1 1 | $Y = A + B$          |             |
| <b>NOT</b>  | A      | Y<br>0<br>1                   | $Y = A'$             |             |
| <b>NAND</b> | A B    | Y<br>0 0<br>0 1<br>1 0<br>1 1 | $Y = (A \bullet B)'$ |             |
| <b>NOR</b>  | A B    | Y<br>0 0<br>0 1<br>1 0<br>1 1 | $Y = (A + B)'$       |             |
| <b>XOR</b>  | A B    | Y<br>0 0<br>0 1<br>1 0<br>1 1 | $Y = A$              |             |
| <b>XNOR</b> | A B    | Y<br>0 0<br>0 1<br>1 0<br>1 1 | $Y = (A)'$           |             |

## Mnemonic

“All Operations Need Necessary eXecution” (first letter of each gate - AND, OR, NOT, NAND, NOR, XOR).

## Question 3(a) [3 marks]

Briefly explain 4:2 Encoder.

## Solution

4-to-2 Encoder Overview:

| Function           | Description                                                                                                     | Truth Table                                                   |
|--------------------|-----------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|
| <b>4:2 Encoder</b> | Converts 4 input lines to 2 output lines<br>Only one input active at a time<br>Input position encoded in binary | $I_0 I_1 I_2 I_3$<br>1 0 0 0<br>0 1 0 0<br>0 0 1 0<br>0 0 0 1 |

**Diagram: 4:2 Encoder:**

```
flowchart TD
    I0["I_{0}"] --> E["4:2 Encoder"]
    I1["I_{1}"] --> E
    I2["I_{2}"] --> E
    I3["I_{3}"] --> E
    E --> Y1["Y_{1}"]
    E --> Y0["Y_{0}"]
```

**Mnemonic**

“Input Position Creates Output” for encoder function.

**Question 3(b) [4 marks]**

Explain 4-bit Parallel adder using full adder blocks.

**Solution**

**4-bit Parallel Adder:**

| Component             | Function                                                 |
|-----------------------|----------------------------------------------------------|
| <b>Full Adder</b>     | Adds 3 bits (A, B, Carry-in) producing Sum and Carry-out |
| <b>Parallel Adder</b> | Connects 4 full adders with carry propagation            |

**Diagram: 4-bit Parallel Adder:**

```
flowchart LR
    A0["A_{0}"] --> FA0["FA"]
    B0["B_{0}"] --> FA0
    CO0["C_{0=0}"] --> FA0
    FA0 --> S0["S_{0}"]
    FA0 --> C1["C_{1}"]
    C1 --> FA1["FA"]

    A1["A_{1}"] --> FA1
    B1["B_{1}"] --> FA1
    FA1 --> S1["S_{1}"]
    FA1 --> C2["C_{2}"]
    C2 --> FA2["FA"]

    A2["A_{2}"] --> FA2
    B2["B_{2}"] --> FA2
    FA2 --> S2["S_{2}"]
    FA2 --> C3["C_{3}"]
    C3 --> FA3["FA"]

    A3["A_{3}"] --> FA3
    B3["B_{3}"] --> FA3
    FA3 --> S3["S_{3}"]
    FA3 --> C4["C_{4}"]
```

**Mnemonic**

“Carry Always Passes Right” for the carry propagation in parallel adder.

**Question 3(c) [7 marks]**

Describe 8:1 Multiplexer with truth table, equation and circuit diagram.

## Solution

### 8:1 Multiplexer:

| Component      | Description                                           | Function                                      |
|----------------|-------------------------------------------------------|-----------------------------------------------|
| <b>8:1 MUX</b> | Data selector with 8 inputs, 3 select lines, 1 output | Selects one of 8 inputs based on select lines |

### Truth Table:

| Select Lines  | Output |
|---------------|--------|
| $S_2 S_1 S_0$ | Y      |
| 0 0 0         | $D_0$  |
| 0 0 1         | $D_1$  |
| 0 1 0         | $D_2$  |
| 0 1 1         | $D_3$  |
| 1 0 0         | $D_4$  |
| 1 0 1         | $D_5$  |
| 1 1 0         | $D_6$  |
| 1 1 1         | $D_7$  |

**Boolean Equation:**  $Y = S'_2 S'_1 S'_0 D_0 + S'_2 S'_1 S_0 D_1 + S'_2 S_1 S'_0 D_2 + S'_2 S_1 S_0 D_3 + S_2 S'_1 S'_0 D_4 + S_2 S'_1 S_0 D_5 + S_2 S_1 S'_0 D_6 + S_2 S_1 S_0 D_7$

**Diagram: 8:1 MUX:**

```
flowchart TD
    D0["D_{0}"] --> MUX["8:1 MUX"]
    D1["D_{1}"] --> MUX
    D2["D_{2}"] --> MUX
    D3["D_{3}"] --> MUX
    D4["D_{4}"] --> MUX
    D5["D_{5}"] --> MUX
    D6["D_{6}"] --> MUX
    D7["D_{7}"] --> MUX
    S0["S_{0}"] --> MUX
    S1["S_{1}"] --> MUX
    S2["S_{2}"] --> MUX
    MUX --> Y["Y"]
```

## Mnemonic

“Select Decides Data Output” for multiplexer operation.

## Question 3(a) OR [3 marks]

Draw the logic circuit of half Subtractor and explain its working.

## Solution

### Half Subtractor:

| Function               | Description                                        | Truth Table                     |
|------------------------|----------------------------------------------------|---------------------------------|
| <b>Half Subtractor</b> | Subtracts two bits producing Difference and Borrow | A B<br>0 0<br>0 1<br>1 0<br>1 1 |

### Logic Circuit:

```
flowchart TD
    A["A"] --{-{-}} XOR[""]
    B["B"] --{-{-}} XOR
    XOR --{-{-}} D["D = A"]
    A1["A{"}"] --{-{-}} AND["•"]
    B1["B{"}"] --{-{-}} AND
    AND --{-{-}} Bout["Bout = A•B"]
```

### Equations:

- Difference (D) =  $A \oplus B$
- Borrow out (Bout) =  $A' \bullet B$

### Mnemonic

“Different Bits Borrow” for half subtractor operation.

## Question 3(b) OR [4 marks]

Explain 3:8 Decoder with truth table and circuit diagram.

### Solution

#### 3:8 Decoder:

| Function           | Description                                                                             | Truth Table (Partial) |
|--------------------|-----------------------------------------------------------------------------------------|-----------------------|
| <b>3:8 Decoder</b> | Converts 3-bit binary input<br>to 8 output lines<br>Only one output active at a<br>time | $A_2 A_1 A_0$         |
|                    |                                                                                         | 0 0 0                 |
|                    |                                                                                         | 0 0 1                 |
|                    |                                                                                         | ...                   |
|                    |                                                                                         | 1 1 1                 |

### Circuit Diagram:

```
flowchart TD
    A0["A_{0}"] --{-{-}} Dec["3:8 Decoder"]
    A1["A_{1}"] --{-{-}} Dec
    A2["A_{2}"] --{-{-}} Dec
    Dec --{-{-}} Y0["Y_{0}"]
    Dec --{-{-}} Y1["Y_{1}"]
    Dec --{-{-}} Y2["Y_{2}"]
    Dec --{-{-}} Y3["Y_{3}"]
    Dec --{-{-}} Y4["Y_{4}"]
    Dec --{-{-}} Y5["Y_{5}"]
    Dec --{-{-}} Y6["Y_{6}"]
    Dec --{-{-}} Y7["Y_{7}"]
```

### Equations:

- $Y_0 = A'_2 A'_1 A'_0$
- $Y_1 = A'_2 A'_1 A_0$
- ...
- $Y_7 = A_2 A_1 A_0$

### Mnemonic

“Binary Input Activates Output” for decoder operation.

### Question 3(c) OR [7 marks]

Explain Gray to Binary code converter with truth table, equation and circuit diagram.

#### Solution

##### Gray to Binary Converter:

| Function              | Description                                                                                                                                 | Table: Gray to Binary                                       |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|
| <b>Gray to Binary</b> | Converts Gray code to Binary code<br>MSB of binary equals MSB of gray<br>Each binary bit is XOR of current gray bit and previous binary bit | Gray<br>0000<br>0001<br>0011<br>0010<br>0110<br>...<br>0111 |
|                       |                                                                                                                                             | 0010                                                        |
|                       |                                                                                                                                             | 0110                                                        |
|                       |                                                                                                                                             | ...                                                         |
|                       |                                                                                                                                             | 0111                                                        |

##### Circuit Diagram:

```
flowchart LR
    G3["G_{3}"] --> B3["B_{3}"]
    G3 --> XOR1[""]
    G2["G_{2}"] --> XOR1
    XOR1 --> B2["B_{2}"]
    XOR1 --> XOR2[""]
    G1["G_{1}"] --> XOR2
    XOR2 --> B1["B_{1}"]
    XOR2 --> XOR3[""]
    G0["G_{0}"] --> XOR3
    XOR3 --> B0["B_{0}"]
```

##### Equations:

- $B_3 = G_3$
- $B_2 = G_3 \oplus G_2$
- $B_1 = B_2 \oplus G_1$
- $B_0 = B_1 \oplus G_0$

#### Mnemonic

“MSB Stays, Rest XOR” for Gray to Binary conversion.

### Question 4(a) [3 marks]

Explain D flip flop with truth table and circuit diagram.

#### Solution

##### D Flip-Flop:

| Function           | Description                                       | Truth Table   |
|--------------------|---------------------------------------------------|---------------|
| <b>D Flip-Flop</b> | Data/Delay flip-flop<br>Q follows D at clock edge | CLK<br>↑<br>↑ |

### Circuit Diagram:

```
flowchart LR
    D["D"] --> FF1["D Flip{-}Flop"]
    CLK["Clock"] --> FF1
    FF1 --> Q1["Q"]
    FF1 --> Qnot1["Qnot"]
    Q1 --> Qnot1
```

### Characteristic Equation:

- $Q(\text{next}) = D$

### Mnemonic

“Data Delays one clock” for D flip-flop operation.

## Question 4(b) [4 marks]

Explain working of Master Slave JK flip flop.

### Solution

#### Master-Slave JK Flip-Flop:

| Component | Operation                                     | Truth Table |
|-----------|-----------------------------------------------|-------------|
| Master    | Samples inputs when $\text{CLK} = 1$          | J K         |
| Slave     | Transfers master output when $\text{CLK} = 0$ | 0 0         |
|           |                                               | 0 1         |
|           |                                               | 1 0         |
|           |                                               | 1 1         |

#### Diagram: Master-Slave JK:

```
flowchart LR
    J["J"] --> Master["Master JK"]
    K["K"] --> Master
    CLK["Clock"] --> Master
    Master --> Slave["Slave JK"]
    Slave --> Q1["Q"]
    Slave --> Qnot1["Qnot"]
    Q1 --> Qnot1
```

### Working:

- **Master stage:** Captures input during clock high
- **Slave stage:** Updates output during clock low
- **Prevents race condition** by separating input capture and output update

### Mnemonic

“Master Samples, Slave Transfers” for master-slave operation.

## Question 4(c) [7 marks]

Classify Shift Registers with the help of Block diagram and Explain any one of them in detail.

### Solution

#### Shift Register Classification:

| Type        | Description              | Function                                   |
|-------------|--------------------------|--------------------------------------------|
| <b>SISO</b> | Serial In Serial Out     | Data enters and exits serially, bit by bit |
| <b>SIPO</b> | Serial In Parallel Out   | Data enters serially, exits in parallel    |
| <b>PISO</b> | Parallel In Serial Out   | Data enters in parallel, exits serially    |
| <b>PIPO</b> | Parallel In Parallel Out | Data enters and exits in parallel          |

### SIP0 Shift Register in Detail:

```
flowchart LR
    Din["Data In"] --> FF1["FF_{1}"]
    FF1 --> FF2["FF_{2}"]
    FF2 --> FF3["FF_{3}"]
    FF3 --> FF4["FF_{4}"]
    CLK["Clock"] --> FF1
    CLK --> FF2
    CLK --> FF3
    CLK --> FF4
    FF1 --> Q0["Q_{0}"]
    FF2 --> Q1["Q_{1}"]
    FF3 --> Q2["Q_{2}"]
    FF4 --> Q3["Q_{3}"]
```

### Working of SIP0 Shift Register:

- Serial data enters at Data-In pin, one bit per clock cycle
- Each flip-flop passes its content to the next on clock pulse
- After 4 clock cycles, 4-bit data is stored in all flip-flops
- Parallel output available from Q0-Q3 simultaneously

### Timing Diagram for SIP0:

|       |                                |
|-------|--------------------------------|
| Clock | \_     \_     \_     \_     \_ |
| Data  | \_ \_ \_     \_ \_ \_     \_   |
| Q0    | \_ \_ \_     \_ \_ \_     \_   |
| Q1    | \_ \_ \_ \_     \_ \_          |
| Q2    | \_ \_ \_ \_ \_     \_ \_       |
| Q3    | \_ \_ \_ \_ \_ \_     \_       |

### Mnemonic

“Serial Inputs Parallel Outputs” for SIP0 operation.

### Question 4(a) OR [3 marks]

Explain SR flip flop with truth table and circuit diagram.

### Solution

#### SR Flip-Flop:

| Function            | Description                                 | Truth Table |
|---------------------|---------------------------------------------|-------------|
| <b>SR Flip-Flop</b> | Set-Reset flip-flop<br>Basic memory element | S R         |
|                     |                                             | 0 0         |
|                     |                                             | 0 1         |
|                     |                                             | 1 0         |
|                     |                                             | 1 1         |

**Circuit Diagram:**

```
flowchart LR
    S["S"] --> NOR1["NOR1"]
    NOR1 --> QN["QN"]
    NOR1 --> Q["Q"]
    R["R"] --> NOR2["NOR2"]
    Q --> NOR2
    NOR2 --> QN
```

**Mnemonic**

“Set to 1, Reset to 0” for SR flip-flop operation.

### Question 4(b) OR [4 marks]

Describe JK flip flop with truth table and circuit diagram.

**Solution**

**JK Flip-Flop:**

| Function            | Description                                         | Truth Table |
|---------------------|-----------------------------------------------------|-------------|
| <b>JK Flip-Flop</b> | Improved SR flip-flop<br>Resolves invalid condition | J K         |
|                     |                                                     | 0 0         |
|                     |                                                     | 0 1         |
|                     |                                                     | 1 0         |
|                     |                                                     | 1 1         |

**Circuit Diagram:**

```
flowchart LR
    J["J"] --> AND1["AND1"]
    Qn["QN"] --> AND1
    AND1 --> OR1["OR"]
    AND1 --> AND2["AND2"]
    K["K"] --> AND2
    Q["Q"] --> AND2
    AND2 --> OR1
    OR1 --> FF["FF"]
    CLK["Clock"] --> FF
    FF --> Q
    FF --> Qn
```

**Characteristic Equation:**

- $Q(\text{next}) = J \cdot Q' + K' \cdot Q$

**Mnemonic**

“Jump-Keep-Toggle” for JK flip-flop states (J=1 K=0: Jump to 1,  
J=0  
K=0: Keep state,  
J=1  
K=1: Toggle).

### Question 4(c) OR [7 marks]

Describe 4-bit Asynchronous UP Counter with truth table and circuit diagram.

## Solution

4-bit Asynchronous UP Counter:

| Function                    | Description                                                                                         | Count Sequence                                                                                                   |
|-----------------------------|-----------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|
| <b>Asynchronous Counter</b> | Also called ripple counter<br>Clock drives only first FF<br>Each FF triggered by previous FF output | 0000 → 0001 → 0010 → 0011<br>0100 → 0101 → 0110 → 0111<br>1000 → 1001 → 1010 → 1011<br>1100 → 1101 → 1110 → 1111 |

Circuit Diagram:

```
flowchart LR
    CLK["Clock"] --> JK1["JK FF_{0}"]
    JK1 --> Q0["Q_{0}"]
    Q0 --> JK2["JK FF_{1}"]
    JK2 --> Q1["Q_{1}"]
    Q1 --> JK3["JK FF_{2}"]
    JK3 --> Q2["Q_{2}"]
    Q2 --> JK4["JK FF_{3}"]
    JK4 --> Q3["Q_{3}"]
```

Working:

- First FF toggles on every clock pulse
- Second FF toggles when first FF goes from 1 to 0
- Third FF toggles when second FF goes from 1 to 0
- Fourth FF toggles when third FF goes from 1 to 0

## Mnemonic

“Ripple Carries Propagation Delay” for asynchronous counter operation.

## Question 5(a) [3 marks]

Compare following logic families: TTL, CMOS, ECL

## Solution

Logic Families Comparison:

| Parameter                | TTL                 | CMOS       | ECL                 |
|--------------------------|---------------------|------------|---------------------|
| <b>Technology</b>        | Bipolar transistors | MOSFETs    | Bipolar transistors |
| <b>Power Consumption</b> | Medium              | Very low   | High                |
| <b>Speed</b>             | Medium              | Low-Medium | Very high           |
| <b>Noise Immunity</b>    | Medium              | High       | Low                 |
| <b>Fan-out</b>           | 10                  | 50+        | 25                  |
| <b>Supply Voltage</b>    | 5V                  | 3-15V      | -5.2V               |

## Mnemonic

“Technology Controls Many Electrical Characteristics” for comparing logic families.

## Question 5(b) [4 marks]

Compare Combinational and Sequential Logic Circuits.

### Solution

#### Combinational vs Sequential Circuits:

| Parameter                | Combinational Circuits | Sequential Circuits               |
|--------------------------|------------------------|-----------------------------------|
| <b>Output depends on</b> | Current inputs only    | Current inputs and previous state |
| <b>Memory</b>            | No memory              | Has memory elements               |
| <b>Feedback</b>          | No feedback paths      | Contains feedback paths           |
| <b>Examples</b>          | Adders, MUX, Decoders  | Flip-flops, Counters, Registers   |
| <b>Clock</b>             | No clock required      | Clock often required              |
| <b>Design approach</b>   | Truth tables, K-maps   | State diagrams, tables            |

#### Diagram: Comparison:

```
flowchart TB
    A["Combinational Logic"] --> B["Outputs = f(Current Inputs)"]
    C["Sequential Logic"] --> D["Outputs = f(Current Inputs, Previous State)"]
```

### Mnemonic

“Current Only vs Memory States” for differentiating combinational and sequential circuits.

## Question 5(c) [7 marks]

Define: Fan in, Fan out, Noise margin, Propagation delay, Power dissipation, Figure of merit, RAM

### Solution

#### Digital Electronics Key Definitions:

| Term                     | Definition                                                          | Typical Values         |
|--------------------------|---------------------------------------------------------------------|------------------------|
| <b>Fan-in</b>            | Maximum number of inputs a logic gate can handle                    | TTL: 2-8, CMOS: 100+   |
| <b>Fan-out</b>           | Maximum number of gate inputs that can be driven by a single output | TTL: 10, CMOS: 50      |
| <b>Noise margin</b>      | Maximum noise voltage that can be added before causing error        | TTL: 0.4V, CMOS: 1.5V  |
| <b>Propagation delay</b> | Time taken for change in input to cause change in output            | TTL: 10ns, CMOS: 20ns  |
| <b>Power dissipation</b> | Power consumed by gate during operation                             | TTL: 10mW, CMOS: 0.1mW |
| <b>Figure of merit</b>   | Product of speed and power (lower is better)                        | TTL: 100pJ, CMOS: 2pJ  |
| <b>RAM</b>               | Random Access Memory - temporary storage device                     | Types: SRAM, DRAM      |

#### Diagram: Digital Parameter Relationships:

```
flowchart LR
    A["Lower Propagation Delay"] --> B["Speed"]
    C["Lower Power Dissipation"] --> D["Efficiency"]
    B --> E["Figure of Merit"]
    D --> E
```

## Mnemonic

“Fast Power Needs Proper Figure Ratings” for remembering the parameter terms.

### Question 5(a) OR [3 marks]

Describe steps and the need of E-waste management of Digital ICs.

#### Solution

##### E-waste Management for Digital ICs:

| Step                 | Description                                   | Importance                 |
|----------------------|-----------------------------------------------|----------------------------|
| <b>Collection</b>    | Separate collection of electronic waste       | Prevents improper disposal |
| <b>Segregation</b>   | Separating ICs from other components          | Enables targeted recycling |
| <b>Dismantling</b>   | Removal of hazardous parts                    | Reduces environmental harm |
| <b>Recovery</b>      | Extracting valuable materials (gold, silicon) | Conserves resources        |
| <b>Safe disposal</b> | Proper disposal of non-recyclable parts       | Prevents pollution         |

##### Need for E-waste Management:

- **Hazardous Materials:** ICs contain lead, mercury, cadmium
- **Resource Conservation:** Recovers precious metals and rare materials
- **Environmental Protection:** Prevents soil and water contamination
- **Health Safety:** Reduces exposure to toxic substances

## Mnemonic

“Collection Starts Dismantling Recovery Safely” for e-waste management steps.

### Question 5(b) OR [4 marks]

Explain working of Ring Counter with circuit diagram.

#### Solution

##### Ring Counter:

| Function            | Description                                                                                                 | Count Sequence                   |
|---------------------|-------------------------------------------------------------------------------------------------------------|----------------------------------|
| <b>Ring Counter</b> | Circular shift register with single 1<br>Only one flip-flop is set at any time<br>N flip-flops for N states | 1000 → 0100 → 0010 → 0001 → 1000 |