

## CSE1003 Digital logic design syllabus

| Course code                                                                                                                                                                                                                                                                                                                |                            |         |            | Digital Logic and Design     |   |   |   |  |  |  |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|---------|------------|------------------------------|---|---|---|--|--|--|--|--|--|
| CSE1003                                                                                                                                                                                                                                                                                                                    |                            |         |            | 3                            | 0 | 2 | 0 |  |  |  |  |  |  |
| Pre-requisite                                                                                                                                                                                                                                                                                                              |                            | -       |            | Syllabus version<br>V. XX.XX |   |   |   |  |  |  |  |  |  |
| <b>Course Objectives:</b>                                                                                                                                                                                                                                                                                                  |                            |         |            |                              |   |   |   |  |  |  |  |  |  |
| 1. Introduce the concept of digital and binary systems<br>2. Design and analyze combinational logic circuits.<br>3. Design and analyze sequential logic circuits.<br>4. Design functional blocks of a digital system.<br>5. Reinforce theory and techniques taught in the classroom through experiments in the laboratory. |                            |         |            |                              |   |   |   |  |  |  |  |  |  |
| <b>Expected Course Outcome:</b>                                                                                                                                                                                                                                                                                            |                            |         |            |                              |   |   |   |  |  |  |  |  |  |
| CO1: Comprehend the different types of number systems.                                                                                                                                                                                                                                                                     |                            |         |            |                              |   |   |   |  |  |  |  |  |  |
| CO2: Evaluate and simplify logic functions using Boolean Algebra and K-map                                                                                                                                                                                                                                                 |                            |         |            |                              |   |   |   |  |  |  |  |  |  |
| CO3: Design minimal combinational logic circuits.                                                                                                                                                                                                                                                                          |                            |         |            |                              |   |   |   |  |  |  |  |  |  |
| CO4: Analyze the operation of medium complexity standard combinational circuits like the encoder, decoder, multiplexer, demultiplexer.                                                                                                                                                                                     |                            |         |            |                              |   |   |   |  |  |  |  |  |  |
| CO5: Design different sequential components and analyze and design the FSM                                                                                                                                                                                                                                                 |                            |         |            |                              |   |   |   |  |  |  |  |  |  |
| CO6: Design different types of registers and counters using flip flops                                                                                                                                                                                                                                                     |                            |         |            |                              |   |   |   |  |  |  |  |  |  |
| CO7: Design Arithmetic and Logic Circuits                                                                                                                                                                                                                                                                                  |                            |         |            |                              |   |   |   |  |  |  |  |  |  |
| <b>Student Learning Outcomes (SLO):</b>   1,2,5,14                                                                                                                                                                                                                                                                         |                            |         |            |                              |   |   |   |  |  |  |  |  |  |
| Module:1                                                                                                                                                                                                                                                                                                                   | INTRODUCTION               | 3 hours | SLO: 1     |                              |   |   |   |  |  |  |  |  |  |
| Number System - Base Conversion- Binary Codes - Complements(Binary and Decimal)                                                                                                                                                                                                                                            |                            |         |            |                              |   |   |   |  |  |  |  |  |  |
| Module:2                                                                                                                                                                                                                                                                                                                   | BOOLEAN ALGEBRA            | 8 hours | SLO: 2     |                              |   |   |   |  |  |  |  |  |  |
| Boolean algebra - Properties of Boolean algebra - Boolean functions - Canonical and Standard forms - Logic gates - Universal gates - Karnaugh map - Don't care conditions - Tabulation Method                                                                                                                              |                            |         |            |                              |   |   |   |  |  |  |  |  |  |
| Module:3                                                                                                                                                                                                                                                                                                                   | COMBINATIONAL CIRCUIT - I  | 4 hours | SLO: 2,5   |                              |   |   |   |  |  |  |  |  |  |
| Adder -Subtractor- Code Converter -Analyzing a Combinational Circuit                                                                                                                                                                                                                                                       |                            |         |            |                              |   |   |   |  |  |  |  |  |  |
| Module:4                                                                                                                                                                                                                                                                                                                   | COMBINATIONAL CIRCUIT - II | 6 hours | SLO: 2,5   |                              |   |   |   |  |  |  |  |  |  |
| Binary Parallel Adder- Look ahead carry - Magnitude Comparator - Decoders - Encoders - Multiplexers - Demultiplexers                                                                                                                                                                                                       |                            |         |            |                              |   |   |   |  |  |  |  |  |  |
| Module:5                                                                                                                                                                                                                                                                                                                   | SEQUENTIAL CIRCUITS - I    | 6 hours | SLO: 1,2,5 |                              |   |   |   |  |  |  |  |  |  |
| Flip Flops - Sequential Circuit: Design and Analysis - Finite State Machine: Moore and Mealy model - Sequence Detector                                                                                                                                                                                                     |                            |         |            |                              |   |   |   |  |  |  |  |  |  |
| Module:6                                                                                                                                                                                                                                                                                                                   | SEQUENTIAL CIRCUITS - II   | 7 hours | SLO: 2,5   |                              |   |   |   |  |  |  |  |  |  |
| Registers - Shift Registers - Counters - Ripple and Synchronous Counters - Modulo counters - Ring and Johnson counters                                                                                                                                                                                                     |                            |         |            |                              |   |   |   |  |  |  |  |  |  |

## CSE1003 Digital logic design syllabus

|                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Design of Multiplexer and De multiplexer            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Design of Magnitude Comparator                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Design of CodeConverter                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| <b>Sequential Circuit Design</b>                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Design of Mealy and Moore circuit                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Implementation of Shift registers                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Design of 4-bit Counter                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Design of Ring Counter                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| <b>List of Challenging Experiments (Indicative)</b> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 1                                                   | Consider four seats, numbered 0 to 3, arranged in a circle and described by Boolean variables (bit 0 to bit 3). Boolean variable bit0 true if seat 0 is occupied and bit0 false if the seat is not occupied; likewise for 11, 12, and 13. Write a Boolean expression that's true if at least two people are sitting next to each other and at least one seat is not occupied and design the circuit using basic gates                                                                                                                                                                         |
| 2                                                   | Controller of a car has three control switches, Accelerator (A), Brake (B) and Clutch (C). A Car runs if A is pressed and either (B and C are not pressed or C is pressed and B is not pressed). If the car is moving, then pressing A will stop the car. If the car is not moving, then pressing A will start the car. If all the three switches are pressed together then we can't predict the result. In all other cases, car will be in off state. Design a circuit to implement this scenario using Universal gates.                                                                     |
| 3                                                   | A digitally controlled locker works based on a control switch and two keys which are entered by the user. Each key has a 2-bit binary representation. If the control switch is pressed, the locker system will accept the digits of two keys into the controller unit. Otherwise, the locker system will pass the sum of the two numbers to the controller unit. Design a circuit to determine the input to the controller unit.                                                                                                                                                              |
| 4                                                   | The controller unit in the above problem compares the input data with the predefined data to allow access to the locker. Assuming the predefined key to be (01)2, design the circuit that outputs true if the predefined key and the input to the controller unit are similar.                                                                                                                                                                                                                                                                                                                |
| 5                                                   | A queue handling system has a capacity of 5 customers which serves on first come first served basis. A display unit is used to display the number of customers waiting in the queue. Whenever a customer leaves the queue, the count is reduced by one and the count is increased by one if a customer joins a queue. Two sensors (control signals) are used to sense customers leaving and joining the queue respectively. Design a circuit that displays the number of customers waiting in the queue in binary format using LEDs. Binary '1' is represented by LED glow and '0' otherwise. |
| Total Laboratory Hours                              | 30 hours                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Mode of evaluation:                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Recommended by Board of Studies                     | DD-MM-YYYY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Approved by Academic Council                        | No. xx Date DD-MM-YYYY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                       |                  |            |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|------------------|------------|
| Module:7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ARITHMETIC LOGIC UNIT | 9 hours          | SLO: 1,2,5 |
| Bus Organization- ALU-Design of ALU-Status Register-Design of Shifter - Processor Unit- Design of specific Arithmetic Circuits- Accumulator- Design of Accumulator                                                                                                                                                                                                                                                                                                                           |                       |                  |            |
| Module:8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Contemporary issues:  | 2 hours          | SLO: xx    |
| Total Lecture hours: 45 hours                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                       |                  |            |
| Text Book(s)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                       |                  |            |
| 1. J.M. Morris Mano - Digital Logic and Computer Design, Pearson Education India – 1st Edition-2016, ISBN: 9789332542525                                                                                                                                                                                                                                                                                                                                                                     |                       |                  |            |
| References                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                       |                  |            |
| 1. T.A.P. Marwan, D.P. Leach and GoutamSaha – Digital Principles and Applications(SIE) – Tata McGraw Hill 3rd Edition – 2014, ISBN: 9789339203405.<br>2.M. Morris Mano and Michael D.Cleto- Digital Design: With an introduction to Verilog HDL - Pearson Education – 5th Edition- 2014, ISBN:9789332535763<br>3.Thomas Floyd - Digital Fundamentals - Pearson Education-10th Edition – 2011, ISBN: 9788131734483.<br>Authors, book title, year of publication, edition number, press, place |                       |                  |            |
| Mode of Evaluation:                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                       |                  |            |
| <b>Lab (Indicative List of Experiments in the areas of)</b>                                                                                                                                                                                                                                                                                                                                                                                                                                  |                       | SLO: 1, 2, 5, 14 |            |
| Study of Logic Gates                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                       |                  |            |
| Logic gates using discreteComponents                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                       |                  |            |
| Verification of truthtable for logic gates                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                       |                  |            |
| Realization of basic gates using NAND and NOR gates                                                                                                                                                                                                                                                                                                                                                                                                                                          |                       |                  |            |
| Implementation of Logic Circuits                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                       |                  |            |
| Verification of Boolean laws                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                       |                  |            |
| Verification of De Morgan's law                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                       |                  |            |
| Adder and Subtractor                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                       |                  |            |
| Implementation of Half-Adder and Full-Adder                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                       |                  |            |
| Implementation of Half-Subtractor and Full-Subtractor                                                                                                                                                                                                                                                                                                                                                                                                                                        |                       |                  |            |
| Combinational Circuit Design                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                       |                  |            |
| Design of Decoder and Encoder                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                       |                  |            |

| CO-PO MAPPING: |   |
|----------------|---|
| CO1            | * |
| CO2            | * |
| CO3            | * |
| CO4            | * |
| CO5            | * |
| CO6            | * |
| CO7            | * |

  

| 2. Knowledge Areas that contain topics and learning outcomes covered in the course |                                   |
|------------------------------------------------------------------------------------|-----------------------------------|
| Knowledge Area                                                                     | Total Hours of Coverage [ Theory] |
| CE: DIG (Digital Logic)                                                            | 42                                |
| CS: AR Digital Logic and Digital Design                                            | 3                                 |
| Total                                                                              | 45 Hours [45]                     |

  

| 2.1 Body of Knowledge coverage |                      |                                                    |       |
|--------------------------------|----------------------|----------------------------------------------------|-------|
| KA                             | Knowledge Unit       | Topics Covered                                     | Hours |
| CE:                            | History and overview | Introduction to logic circuits, switching, memory, | 1     |

## CSE1003 Digital logic design syllabus

|                 |                                           |                                                                                                                                                                                                                                               |    |
|-----------------|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| DIG 0           |                                           | registers, counters and digital systems                                                                                                                                                                                                       |    |
| CS: AR          | Digital Logic and Digital Systems         |                                                                                                                                                                                                                                               |    |
| CE: DIG 1       | Switching theory                          | Number System and Codes<br>Binary Arithmetic and Complements<br><br>Boolean algebra: Properties of Boolean algebra<br>Boolean functions: Canonical and Standard forms<br>Minimization: Karnaugh map, Don't care conditions, Tabulation Method | 10 |
| CE: DIG 2       | Combinational Logic Circuits              | Logic gates ,Universal gates<br><br>Realization of switching functions using logic gates<br><br>Analyzing a Combinational Circuit                                                                                                             | 2  |
| CS:AR           | Digital Logic and Digital Systems         |                                                                                                                                                                                                                                               |    |
| CE: DIG 3       | Modular design of combinational circuits  | Adder, Subtractor<br>Binary Parallel Adder, Look ahead carry<br>Magnitude Comparator, Code Converter<br>Decoders, Encoders<br>Multiplexers, Demultiplexers                                                                                    | 8  |
| CE: DIG 4 and 5 | Memory Elements Sequential Logic Circuits | Flip Flops<br><br>Sequential Circuit: Design and Analysis<br><br>Finite State Machine: Moore and Mealy model<br><br>Sequence Detector                                                                                                         | 6  |

|           |                                               |                                                                                                                                                                        |    |
|-----------|-----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| CE: DIG 6 | Digital systems design                        | Registers, Shift Registers<br><br>Counters: Ripple and Synchronous Counters, Modulo counters, Ring and Johnson counter                                                 | 7  |
| CE: DIG 6 | Analyze and design functional building blocks | Bus Organization -ALU -Design of ALU -Status Register -Design of Shifter -Processor Unit- Design of specific Arithmetic Circuits - Accumulator - Design of Accumulator | 9  |
| CE: DIG 6 | Recent Trends                                 |                                                                                                                                                                        | 2  |
| CS:AR     | Digital Logic and Digital Systems             |                                                                                                                                                                        |    |
|           |                                               | Total hours                                                                                                                                                            | 45 |

### 3. Where does the course fit in the curriculum?

This course is a

- Core Course.
- Suitable from 2<sup>nd</sup> semester onwards.
- Knowledge of basic electrical and electronics is desirable.

### 4. What is covered in the course?

The digital logic and design covers the digital building blocks and techniques in the design of digital systems. Emphasis is on a building-block approach. This syllabus covers a variety of basic topics, including switching theory, combinational circuits such as adders, subtractors, encoder, decoder, multiplexer, demultiplexer etc. The sequential logic covers memory elements and its application includes design of counters and registers along with functional blocks of a digital computer.

#### 4.1 Part 1: Introduction and Boolean Algebra

## CSE1003 Digital logic design syllabus

This section deals with introduction of number system, binary codes and its arithmetic, Boolean algebra, Boolean function and minimization techniques.

#### 4.2 Part II: Combinational Circuits

This section covers logic gates, universal gates, adder, subtractor, encoder, decoder, multiplexer, de multiplexer and design of a minimal combinational circuit.

#### 4.3 Part III: Sequential Circuits

This section deals with memory elements, design of sequential circuit using memory elements, analysing a sequential circuit, design of finite state machines, registers and counters.

#### 4.4 Part IV: Functional Blocks of a Computer

This section deals with design of functional blocks of a digital computer.

#### 5. What is the format of the course?

This Course is designed with 150 minutes of in-classroom sessions per week, additional video/reading instructional material every week and 100 minutes of lab hours per week. Generally this course has the combination of lectures, in-class discussion, assignments, mandatory off-class reading material, quizzes.

#### 6. How are students assessed?

- Students are assessed on a combination of assignments, continuous and final assessment tests.
- Students will be provided with problem sets for every module.

#### 7. Session wise plan

| Sl. No | Topic Covered                                                                                                             | Class Hour | Lab Hour | levels of mastery | Text/Reference Book | Remarks |
|--------|---------------------------------------------------------------------------------------------------------------------------|------------|----------|-------------------|---------------------|---------|
| 1      | Introduction to logic circuits, switching, memory, registers, counters and digital systems<br><br>Number System and Codes | 3          | 2        | Familiarity       | 1,3                 |         |

|   |                                                                                                                                 |   |   |            |     |  |
|---|---------------------------------------------------------------------------------------------------------------------------------|---|---|------------|-----|--|
| 1 | Binary Arithmetic and Complements                                                                                               |   |   | Usage      |     |  |
| 2 | Boolean algebra: Properties of Boolean algebra<br><br>Boolean functions: Canonical and Standard forms , Simplification          | 3 | 2 | Usage      | 1,4 |  |
| 3 | Minimization: Karnaugh map, Don't care conditions<br><br>Tabulation Method                                                      | 3 |   | Usage      | 1,4 |  |
| 4 | Tabulation Contd.,<br><br>Logic gates, Universal gates, Realization of switching functions using logic gates, Adder, Subtractor | 3 | 2 | Usage      | 1,4 |  |
| 5 | Analyzing a Combinational Circuit,Magnitude Comparator, Code Converter, Binary Parallel Adder                                   | 3 | 4 | Assessment | 1,3 |  |
| 6 | Look ahead carry,<br><br>Decoders, Encoders<br><br>Multiplexers,Demultiplexers                                                  | 3 | 2 | Usage      | 1,3 |  |
| 7 | Flip Flops<br><br>Sequential Circuit: Design and Analysis                                                                       | 3 | 2 | Assessment | 1,3 |  |
| 8 | Finite State Machine: Moore and Mealy model, Sequence Detector                                                                  | 3 | 2 | Usage      | 1,5 |  |

|                     |                                                                  |                                                         |                                      |             |     |  |
|---------------------|------------------------------------------------------------------|---------------------------------------------------------|--------------------------------------|-------------|-----|--|
| 10                  | Registers, Shift Registers , Ripple Counters                     | 3                                                       | 2                                    | Assessment  | 1,5 |  |
| 11                  | Synchronous counters, Modulo counters, Ring and Johnson counters | 3                                                       | 4                                    | Usage       | 1   |  |
| 12                  | BusOrganization, DesignofALU                                     | 3                                                       |                                      | Assessment  | 1   |  |
| 13                  | Status Register DesignofShifter                                  | 3                                                       | 2                                    | Usage       | 1   |  |
| 14                  | Processor Unit DesignofspecificArithmeticCircuits                | 3                                                       |                                      | Familiarity | 1   |  |
| 15                  | DesignofAccumulator Recent Trends                                | 3                                                       |                                      | Familiarity | 1   |  |
| Total hours covered |                                                                  | 45 Hours<br>(3 Credit hours /week<br>15 Weeks schedule) | 30 Hours<br>(1 Credit hours / week ) |             |     |  |

**Module 1 Introduction      3 hours**

- Number System
- Base Conversion
- Binary Codes
- Complements (Binary and Decimal)

## CSE1003 Digital Logic and Design

### Module 1 Introduction Lecture 1

Dr. S. Hemamalini

Professor

School of Electrical Engineering  
VIT Chennai**Digital Systems**

- Digital age and information age
- Digital computers
  - general purposes
  - many scientific, industrial and commercial applications
- Digital systems
  - telephone switching exchanges
  - digital camera
  - electronic calculators, PDA's
  - digital TV
- Discrete information-processing systems
  - manipulate discrete elements of information



# Signals

Analog signal

- Is a continuous signal ✓
  - Any voltage level is possible at any time ✓
  - Explicit formula
    - E.g  $V(t)=f(t, \text{parameters})$
  - Graphical representation of the signal



$$\rightarrow \text{soon} \quad V(t) = \frac{d(i(t))}{dt}$$

Digital signal

- Is a discrete time signal
  - Discrete number of voltage levels are possible at specified time
  - conveyed by the **on /off states** of pulses in a pulse train
  - **ON** or the **off** state is a *bit*, and the time interval for the **on** or **off** state is called a *bit interval*.
  - Algorithm
    - Set of conditions and operations
  - $V(t)$  can be 1 or 0



$$V(t) = \begin{cases} 0 & 0 \leq t < t_1 \\ t_1 & t_1 \leq t < t_2 \\ 0 & t \geq t_2 \end{cases}$$

# Signal

- An information variable represented by physical quantity
  - For digital systems, the variable takes on discrete values
    - Two level, or binary values are the most prevalent values
  - Binary values are represented abstractly by:
    - digits 0 and 1
    - words (symbols) False (F) and True (T)
    - words (symbols) Low (L) and High (H)
    - words On and Off
  - Binary values are represented by values or ranges of values of physical quantities



# Digital System

- Digital systems contain devices that process the physical quantities represented in digital form.
  - A digital system is an interconnection of digital modules.
  - Digital techniques and systems -advantages
    - easier to design ✓
    - have higher accuracy ✓
    - easy programmability ✓
    - noise immunity ✓
    - easier storage of data ✓
    - ease of fabrication in integrated circuit form, leading to availability of more complex functions in a smaller size.
  - The real world, however, is analogue.
  - Analogue variables are digitized at the input with the help of an analogue-to-digital converter block and reconverted back to analogue form at the output using a digital-to-analogue converter block.
  - To understand the operation of each digital module, it is necessary to have a basic knowledge of digital circuits and their logical function.

The diagram illustrates a digital control system architecture. It starts with a 'Sensor' block, which outputs an 'analog voltage'. This signal is fed into an 'ADC' (Analogue-to-Digital Converter) block. The ADC converts the analog signal into a digital format, which is then transmitted through a 'Transmission' block. On the receiving end, the digital signal passes through a 'Computer' and a 'DAC' (Digital-to-Analogue Converter). The DAC converts the digital signal back into an 'analog signal'. This analog signal is sent to an 'Actuator' block, which finally controls a 'Motor'.



## Number Systems

Decimal → 10 base  
 Binary → 2  
 Octal → 8  
 Hexadecimal → 16

- Representation of numbers
- Radix: "base", the primitive unit for group of numbers, e.g. for decimal arithmetic radix=10 ("base" 10)
- For every system, we need arithmetic operations (addition, subtraction, multiplication)
- Also, conversion from one base to the other

23-Feb-21

## Introduction to Number Systems

### Positional Notation

- A positive number N can be written as:

$$N = (a_{n-1} a_{n-2} \dots a_1 a_0, a_{-1} a_{-2} \dots a_{-m})_r$$

LSD

.. = radix point

r = radix or base of number system

n = number of integer digits to the left of radix point

m = number of fractional digits to the right of radix point

$a_i$  = integer digit i  $0 \rightarrow n-1$

$a_j$  = fractional digit j  $-1 \rightarrow -m$

$a_{n-1}$  = most significant digit

$a_{-m}$  = least significant digit

1325

$$1325_{10} = 1 \times 10^3 + 3 \times 10^2 + 2 \times 10^1 + 5 \times 10^0$$

$$1000 + 300 + 20 + 5 = 1325$$

### Polynomial Notation

- A positive number N can also be written as:

$$N = \sum_{i=-m}^{n-1} a_i r^i$$

where  $a_i$  is a coefficient between 0 to 9, and i denotes the weight ( $= 10^i$ ) of  $a_i$

1325  
a<sub>3</sub> a<sub>2</sub> a<sub>1</sub> a<sub>0</sub>

## Binary Arithmetic

### Binary Addition

- Single Bit Addition Table

$$0 + 0 = 0$$

$$0 + 1 = 1$$

$$1 + 0 = 1$$

$$1 + 1 = 10$$

Note "carry"

$$\begin{array}{r} 1101 \\ + 0111 \\ \hline 10100 \end{array}$$

↑  
Carry sum

### Binary Subtraction

- Single Bit Subtraction Table

$$0 - 0 = 0$$

$$1 - 0 = 1$$

$$1 - 1 = 0$$

$$0 - 1 = 1 \text{ with a "borrow"}$$

$$\begin{array}{r} 0 \\ 1101 \\ - 0111 \\ \hline 0110 \end{array}$$

## Conversion Methods - Series substitution

Expand number in original base using

$$N = \sum_{i=-m}^{n-1} a_i r^i$$

Convert from

Binary to Decimal

$$(1001.0101)_2 = 9.3125_{10}$$

integer → fractional

$$\begin{aligned} 1001 &= 1 \times 2^3 + 0 \times 2^2 + 0 \times 2^1 + 1 \times 2^0 \\ &= 8 + 0 + 0 + 1 = 9 \end{aligned}$$

$$\begin{aligned} 0101 &= 0 \times 2^{-1} + 1 \times 2^{-2} + 0 \times 2^{-3} + 1 \times 2^{-4} = 0 + 0.25 + 0 + 0.0625 = 0.3125 \end{aligned}$$

Least Significant Bit (MSB)

## Binary Arithmetic

### Binary Multiplication

- Single Bit Multiplication Table

$$0 \times 0 = 0$$

$$1101$$

$$0 \times 1 = 0$$

$$\times 0111$$

$$1 \times 0 = 0$$

$$1101$$

$$1 \times 1 = 1$$

$$\begin{array}{r} 1101 \\ \times 0111 \\ \hline 0000 \\ 1101 \\ \hline 1011011 \end{array}$$

### Binary Division

- Single Bit Division Table

$$0 / 0 = \text{N/A}$$

$$110 \div 11$$

$$0 / 1 = 0$$

$$000$$

$$1 / 0 = \text{N/A}$$

$$11$$

$$1 / 1 = 1$$

$$000$$

## CSE1003 Digital Logic and Design

### Module 1 Introduction Lecture 2

Dr. S. Hemamalini

Professor

School of Electrical Engineering  
VIT Chennai

## **Module 1 Introduction 3 hours**

- Number System
  - **Base Conversion**
  - Binary Codes
  - Complements (Binary and Decimal)

## Base Conversion Methods - Series substitution

## Positional Weights Method

Each binary digit of the number is multiplied by its position weight and the product terms are added to obtain the decimal number.

Expand number in original base using

$$N = \sum_{i=-m}^{n-1} a_i r^i$$

Most Significant Bit (MSB)      Least Significant Bit (LSB)

## Binary to decimal conversion

**Convert 11011.101, to decimal.**

$$\begin{array}{r} \text{Binary to decimal conversion} \\ \text{Convert } \underline{\underline{11011.101}}_2 \text{ to decimal.} \\ 11011.101 = 1 \times 2^4 + 1 \times 2^3 + 0 \times 2^2 + 1 \times 2^1 + 1 \times 2^0 + 1 \times 2^{-1} + 0 \times 2^{-2} + 1 \times 2^{-3} \\ \downarrow 4 \quad \downarrow 3 \quad \downarrow 2 \quad \downarrow 1 \quad \downarrow 0 \\ 2^4 \quad 2^3 \quad 2^2 \quad 2^1 \quad 2^0 \\ = 16 + 8 + 0 + 2 + 1 + 0.5 + 0 + 0.125 = 27.625_{10} \end{array}$$

## Decimal to Binary Conversion - Radix Divide Method

## Converting decimal integer to binary

- To convert a decimal integer to binary, repeatedly divide by 2 (successive division) until the quotient is zero - Double-Dabble method.
  - Last remainder is the MSB. Read the reminders in reverse order (bottom to top) to get the binary form of the number.

## Converting decimal fraction to binary

- To convert a decimal fraction to binary, repeatedly multiply the fractional part by 2 till the fraction part of the product is zero or till the desired accuracy is obtained.
  - The first integer obtained is the MSB. Read the integers from top to bottom to get the binary equivalent fraction.

## Decimal to Binary Conversion - Radix Divide Method

Convert  $163.875_{10}$  to binary.

## Integer part conversion

|         | Quotient | Reminder | LSB |
|---------|----------|----------|-----|
| 163     |          |          |     |
| 163 / 2 | 81       | 1        |     |
| 81 / 2  | 40       | 1        |     |
| 40 / 2  | 20       | 0        |     |
| 20 / 2  | 10       | 0        |     |
| 10 / 2  | 5        | 0        |     |
| 5 / 2   | 2        | 1        |     |
| 2 / 2   | 1        | 0        |     |

| Radix Divide Method        |             |       |
|----------------------------|-------------|-------|
| Fractional part conversion |             |       |
| 0.875                      |             |       |
| 0.875 × 2                  | <u>1.75</u> | 1 MSB |
| 0.75 × 2                   | <u>1.5</u>  | 1     |
| 0.5 × 2                    | 1.0         | 1 LSB |

42  
Practice problem: Convert  $105_{15}$  to binary M S B

## Most Significant Bit

## Octal to Binary Conversion

### Octal to Binary Conversion

Replace each octal digit by its 3-bit binary equivalent.

Convert an octal to binary by substituting the binary equivalents for each digit.

$$317.2_8 = 011 \underline{001} \underline{111.010}_2$$

### Binary to Octal Conversion

- To convert binary to octal, arrange the bits in groups of three, starting from the binary point and working outward
- Insert leading or trailing zeros to complete the groups.
- Convert each group of three bits into its octal equivalent.

$$011 \underline{110} \underline{110.1}_2 = 011 \underline{110} \underline{110.100} = 366.4_8$$

## Octal to Binary Conversion

Convert  $367.52_8$  to binary.

$$011 \underline{110} \underline{111.101010}_2$$

Convert  $01010111001.011100_2$  to octal.

$$010 \underline{101} \underline{111} \underline{001.011100}$$

$$2 \quad 5 \quad 7 \quad 1 \cdot 34_8$$

## Octal to decimal conversion

Multiply each digit in the octal number by the weight of its position and add all the product terms.

Convert  $4057.06_8$  to decimal.

$$4057.06_8 = 4 \times 8^3 + 0 \times 8^2 + 5 \times 8^1 + 7 \times 8^0 + 0 \times 8^{-1} + 6 \times 8^{-2}$$

$$= 2095.09375_{10}$$

## Decimal to Octal conversion

To convert the given decimal integer number to octal, successively divide the given number by 8 till the quotient is 0. The last remainder is the MSD. Reminders read upwards give the equivalent octal integer number.

Convert  $378.93_{10}$  to octal.

| Integer | Q  | R | Fraction        |      |
|---------|----|---|-----------------|------|
| $378/8$ | 47 | 2 | $0.93 \times 8$ | 7.44 |
| $47/8$  | 5  | 7 | $0.44 \times 8$ | 3.52 |
| $5/8$   | 0  | 5 | $0.52 \times 8$ | 4.16 |
|         |    |   | $0.16 \times 8$ | 1.28 |

$572 \cdot 7341_8$

## Hex to Binary Conversion Binary to Hex Conversion

Use the conversion table

| Bin  | Hex | Bin  | Hex |
|------|-----|------|-----|
| 0000 | 0   | 1000 | 8   |
| 0001 | 1   | 1001 | 9   |
| 0010 | 2   | 1010 | A   |
| 0011 | 3   | 1011 | B   |

| Bin  | Hex | Bin  | Hex |
|------|-----|------|-----|
| 0100 | 4   | 1100 | C   |
| 0101 | 5   | 1101 | D   |
| 0110 | 6   | 1110 | E   |
| 0111 | 7   | 1111 | F   |

- Binary to Hex Conversion**
- Divide binary number into 4-bit groups.
  - Substitute hex digit for each group

$$011000011100 \rightarrow 61C_{16}$$

**Hex to Binary Conversion**

$$1E3F_{16}$$

0001\underline{1110}\underline{0011}\underline{1111}\_2

## Hexadecimal to Decimal Conversion

Multiply each digit in the hexadecimal number by its position weight and add all those product terms.

$$\begin{aligned} 5C7_{16} &= 5 \times 16^2 + C \times 16^1 + 7 \times 16^0 \\ &= 5 \times 16^2 + 12 \times 16^1 + 7 \times 16^0 \\ &= 1479_{10} \end{aligned}$$

$$A0F9.0EB_{16} = 41209.0572_{10}$$

## Decimal to Hexadecimal Conversion Radix Divide Method

- Successively divide the integer by 16 till the quotient is zero. Last remainder is MSB.
- Read the remainder from bottom to top and that gives the equ. Hexadecimal integer.
- Multiply the given fraction number by 16 till the product is zero or till the required accuracy is reached.
- First integer is the MSB. Read top to bottom to get the equ. fractional part.

Convert  $2598.675_{10}$  to hexadecimal.

| $2598/16$ | $162/16$ | $10/16$ | $R^{10}$ | $R^9$ | $R^8$ | $R^7$ | $R^6$ | $R^5$ | $R^4$ | $R^3$ | $R^2$ | $R^1$ | $R^0$ | LSB | MSB | denied hex. |
|-----------|----------|---------|----------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-----|-----|-------------|
| 162       | 10       | 0       | 6        | 2     | 10    | 6     | 12    | 12    | 12    | 12    | 12    | 12    | 12    | 12  | 12  | 12          |
| 10        | 2        | 0       | 6        | 2     | 10    | 6     | 12    | 12    | 12    | 12    | 12    | 12    | 12    | 12  | 12  | 12          |
| 10        | 2        | 0       | 6        | 2     | 10    | 6     | 12    | 12    | 12    | 12    | 12    | 12    | 12    | 12  | 12  | 12          |

$$2598.675_{10} = A26.ACCC_{16}$$

## Octal to hexadecimal and hexadecimal to octal conversion



2.12

## Practice problems

- Convert  $756.603_8$  to hexadecimal.
- Convert  $B9F.AE_{16}$  to octal.
- Convert  $1011011011_2$  to hexadecimal.
- Convert  $4BAC_{16}$  to binary.

## CSE1003 Digital Logic and Design

### Module 1 Introduction Lecture 2

Dr. S. Hemamalini  
Professor  
School of Electrical Engineering  
VIT Chennai

### Module 1 Introduction    3 hours

- Number System
- Base Conversion
- Binary Codes
- Complements (Binary and Decimal)

### SIGNED BINARY NUMBERS

- Sign-magnitude representation
- 1's complement representation
- 2's complement representation

Decimal  
 $+9$     $-9$   
 $+1001$     $-1001$

~~1~~ for minus sign  
 1 for plus sign  
 0 for plus sign

### Sign-magnitude Representation

- An additional bit is used as the *sign bit*.
- This sign bit is usually placed as the MSB.
- A 0 is reserved for a positive number and a 1 is reserved for a negative number.
- 8-bit signed binary number

$(01101001)_2$     $+ (105)_{10}$   
 MSB      ↓  
 +ve sign   magnitude 7 bits

$-11101001$     $-(05)_{10}$   
 MSB      ↓  
 -ve no.

Eq.  $\textcircled{0} \overbrace{101100}^{\substack{5 \\ 4 \\ 3 \\ 2 \\ 1 \\ 0}} \text{ find the decimal equivalent}$

MSB      ↓  
 $(+44)_{10}$

$(+44)_{10}$

$1 \times 2^5 + 0 \times 2^4 + 1 \times 2^3 + 1 \times 2^2 + 0 \times 2^1 + 0 \times 2^0 = 44_{10}$

Find the decimal equivalent of the following binary numbers assuming the binary numbers have been represented in sign-magnitude form.

- (a) 0101100 (b) 101000 (c) 1111 (d) 011011

**Solution.**

- (a) Sign bit is 0, which indicates the number is positive.  
Magnitude  $101100 = (44)_{10}$   
Therefore  $(0101100)_2 = (+44)_{10}$ .
- (b) Sign bit is 1, which indicates the number is negative.  
Magnitude  $01000 = (8)_{10}$   
Therefore  $(101000)_2 = (-8)_{10}$ .
- (c) Sign bit is 1, which indicates the number is negative.  
Magnitude  $111 = (7)_{10}$   
Therefore  $(1111)_2 = (-7)_{10}$ .
- (d) Sign bit is 0, which indicates the number is positive.  
Magnitude  $11011 = (27)_{10}$   
Therefore  $(011011)_2 = (+27)_{10}$ .

## 2's Complement Representation

- If 1 is added to 1's complement of a binary number, the resulting number is 2's complement of that binary number.

$$\begin{array}{r} 0110_2 \quad (+6)_{10} \Rightarrow \\ 0110 \quad \text{Given no.} \\ 1001 \quad 1\text{'s complement} \\ + 1 \\ \hline 1010 \quad 2\text{'s complement} \\ \hookrightarrow (-6)_{10}. \end{array}$$



## 1's Complement Representation

- In 1's complement representation, both numbers are a complement of each other.
- If one of the numbers is positive, then the other will be negative with the same magnitude and vice versa.

Binary      Decimal  
 $0111_2$        $(+7)_{10}$   
 $1000_2 \rightarrow$  1's complement representation  
 $\hookrightarrow (-7)_{10}$   
 Represent +5 & -5 in 1's complement form  
 $(+5)_{10} \rightarrow (0101)_2$      $(-5) \rightarrow (1010)_2$

Represent  $(-19)$  in

- (a) Sign-magnitude,
- (b) one's complement, and
- (c) two's complement representation.

- Binary form
- |        |     |     |
|--------|-----|-----|
| $19/2$ | $9$ | $1$ |
| $9/2$  | $4$ | $1$ |
| $4/2$  | $2$ | $0$ |
| $2/2$  | $1$ | $0$ |
- (a)  $110011$  sign magnitude  
~~110011~~ magnitude representation  
 sign
- (b)  $101100$  1's complement representation  $(-19) \rightarrow \underline{\underline{110011}}_2$
- (c)  $101101$  2's complement representation

## COMPLEMENTS

- Complements are used in digital computers for simplifying the subtraction operation and for logical manipulations.
- There are two types of complements for each number system of base- $r$ : the  $r$ 's complement and the  $(r - 1)$ 's complement.
- For a binary system, the value of  $r$  is 2 and hence the complements are 2's and 1's complements.
- For a decimal system the value of  $r$  is 10 and the complements are 10's and 9's complements.
- With the same logic if the number system is octal the complements are 8's and 7's complement, while it is 16's and 15's complements for hexadecimal system.

## $(r-1)$ 's Complement

- If a positive number  $N$  is given in base  $r$  with an integer part of  $n$  digits and a fraction part of  $m$  digits, then the  $(r - 1)$ 's complement of  $N$  is given as  $(r^n - r^m - N)$  for  $N \neq 0$  and 0 for  $N = 0$ .

## The $r$ 's Complement

- If a positive number  $N$  is given in base  $r$  with an integer part of  $n$  digits, the  $r$ 's complement of  $N$  is given as  $r^n - N$  for  $N \neq 0$  and 0 for  $N = 0$ .

## 1'S AND 2'S COMPLEMENT ARITHMETIC

### Subtraction Using 1's Complement

- Binary subtraction can be performed by adding the 1's complement of the subtrahend to the minuend.
- If a carry is generated, remove the carry, add it to the result. This carry is called the end-around carry.
- If the subtrahend is larger than the minuend, then no carry is generated.
- The answer obtained is 1's complement of the true result and opposite in sign.

Subtract binary 10 from binary 101 using 1's complement.  $(10)_2 \rightarrow 2_{10}$   $(101)_2 \rightarrow 5_{10}$

$$\begin{array}{r}
 5 \quad \text{Minuend} \quad 101 \\
 -2 \quad \text{Subtrahend} \quad -010 \\
 \hline
 +3 \quad ? \quad \text{Minuend} \\
 \end{array}$$

101  
 101  
 1's complement of 010  
 010

End of carry  
 (EAC)  $\rightarrow$  010  
 +1 EAC added  
 011  
 ↑  
 +3

Subtract binary 110 from binary 101 using 1's complement.  $(110)_2 \rightarrow 6_{10}$   $101 \rightarrow 5_{10}$

$$\begin{array}{r}
 \text{Decimal} \quad \text{Binary} \\
 5 \quad \text{Minuend} \quad 101 \\
 -6 \quad \text{Subtrahend} \quad -110 \\
 \hline
 -1 \quad ? \quad \text{Minuend} \\
 \end{array}$$

+001  
 110  
 SUM NO endg carry  
 ↑  
 1's complement form of -1

## Subtraction Using 2's Complement

- Binary subtraction can be performed by adding the 2's complement of the subtrahend to the minuend.
- If a carry is generated, discard the carry.
- Now if the subtrahend is larger than the minuend, then no carry is generated.
- The answer obtained is in 2's complement and is negative.
- To get a true answer take the 2's complement of the number and change the sign.
- The advantage of the 2's complement method is that the end-around carry operation present in the 1's complement method is not present here.

Subtract binary 10 from binary 101 using 2's complement.

$$\begin{array}{r}
 5 \quad \text{Minuend} \quad 101 \quad 101 \quad \text{Minuend} \\
 -2 \quad \text{Subtrahend} \quad -010 \quad +110 \quad \text{2's complement of 010} \\
 \hline
 +3 \quad \text{Difference} \quad ? \quad \text{SUM} \\
 \end{array}$$

Extra carry ignored  $\rightarrow$  011  
 ↑  
 +3

Subtract binary 011 from 001 using 2's complement.

$$\begin{array}{r}
 & 001 & \text{Minuend} \\
 - 1 & - 011 & + 101 & \text{2's complement} \\
 \hline
 - 2 & ? & \hline 110 & \text{sum} \\
 \text{No carry} & \nearrow & \uparrow & \text{2's complement form of } 110 \\
 & & & -2
 \end{array}$$

**Module 2**  
**BOOLEAN ALGEBRA**    8 hrs

- Boolean algebra
- Properties of Boolean algebra
- Boolean functions
- Canonical and Standard forms
- Logic gates - Universal gates
- Karnaugh map - Don't care conditions
- Tabulation Method

**CSE1003**  
**Digital Logic and Design**

**Module 2**  
**BOOLEAN ALGEBRA L1**

Dr. S. Hemamalini

Professor

School of Electrical Engineering  
VIT Chennai

## Logic Gates

- The logic gate is the most basic building block of any digital system, including computers.
- Each one of the basic logic gates is a piece of hardware or an electronic circuit that can be used to implement some basic logic expression, also known as Boolean expressions.
- There are three basic logic gates, namely the OR gate, the AND gate and the NOT gate.
- Other logic gates that are derived from these basic gates are the NAND gate, the NOR gate, the EXCLUSIVEOR gate and the EXCLUSIVE-NOR gate.



### Positive and Negative Logic

- The binary variables, can have either of the two states, i.e. the logic '0' state or the logic '1' state.
- These logic states in digital systems such as computers, for instance, are represented by two different voltage levels or two different current levels.

|   |     |      |      |
|---|-----|------|------|
| 1 | ON  | High | +5 V |
| 0 | OFF | Low  | 0 V  |

### Truth Table

- A truth table lists all possible combinations of input binary variables and the corresponding outputs of a logic system.
- The logic system output can be found from the logic expression, often referred to as the Boolean expression, that relates the output with the inputs of that very logic system.



Truth table of a three-input logic system

| A | B | C | Y |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 0 |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 0 |
| 1 | 1 | 1 | 1 |

1  
2  
2 - 4  
3 = 8  
2 = 4





## AND GATE



## Application of an AND gate

- An AND gate is commonly used as an ENABLE or INHIBIT gate to allow or disallow passage of data from one point in the circuit to another.
  - One such application of enabling operation, for instance, is in the measurement of the frequency of a pulsed waveform or the width of a given pulse with the help of a counter.
  - In the case of frequency measurement, a gating pulse of known width is used to enable the passage of the pulse waveform to the counter's clock input.
  - In the case of pulse width measurement, the pulse is used to enable the passage of the clock input to the counter.



## OR GATE



## Application of an OR gate

- An OR gate can be used in all those situations where the occurrence of any one or more than one event needs to be detected or acted upon.



## X-OR Gate



| Input A | Input B | Output $\bar{A}B + A\bar{B}$ |
|---------|---------|------------------------------|
| 0       | 0       | 0                            |
| 0       | 1       | 1                            |
| 1       | 0       | 1                            |
| 1       | 1       | 0                            |

The output of an XOR gate goes HIGH if the inputs are different from each other. XOR gates only come with two inputs.



PIN DIAGRAM :



## NOR Gate



| Input A | Input B | Output $\bar{A} + \bar{B}$ |
|---------|---------|----------------------------|
| 0       | 0       | 1                          |
| 0       | 1       | 0                          |
| 1       | 0       | 0                          |
| 1       | 1       | 0                          |

Combines the NOT function with an OR gate; output goes LOW if one or both inputs are LOW, output goes HIGH when both inputs are LOW.



PIN DIAGRAM :



## NAND Gate



| Input A | Input B | Output $\bar{A} \cdot \bar{B}$ |
|---------|---------|--------------------------------|
| 0       | 0       | 1                              |
| 0       | 1       | 1                              |
| 1       | 0       | 1                              |
| 1       | 1       | 0                              |

Combines the NOT function with an AND gate; output only goes LOW when both inputs are HIGH.



PIN DIAGRAM :



## X-NOR Gate



| Input A | Input B | Output<br>$A.B + \bar{A}.\bar{B}$ |
|---------|---------|-----------------------------------|
| 0       | 0       | 1                                 |
| 0       | 1       | 0                                 |
| 1       | 0       | 0                                 |
| 1       | 1       | 1                                 |

Combines the NOT function with an XOR gate; output goes HIGH if the inputs are the same.

$$Y = (\overline{A \oplus B}) = (A \cdot B + \overline{A} \cdot \overline{B})$$



## OR GATE

- How would you hardware-implement a four-input OR gate using two-input OR gates only?



- Draw the output waveform for the OR gate and the given pulsed input waveforms of Fig.



## NOT Gate

- For the logic circuit arrangements of Figs (a) and (b), draw the output waveform.



In the case of the OR gate arrangement of Fig. (a), the output will be permanently in logic '1' state as the two inputs can never be in logic '0' state together owing to the presence of the inverter.



In the case of the AND gate arrangement of Fig. (b), the output will be permanently in logic '0' state as the two inputs can never be in logic '1' state together owing to the presence of the inverter.

*Show the logic arrangements for implementing:*

(a) a four-input NAND gate using two-input AND gates and NOT gates



## Implementation of basic logic gates using only NAND gates



## Do it by yourself

- Draw the truth table of the logic circuit shown in



| A | B | C | D | Y |
|---|---|---|---|---|
| 0 | 0 | 0 | 0 | 1 |
| 0 | 0 | 0 | 1 | 0 |
| 0 | 0 | 1 | 0 | 1 |
| 0 | 0 | 1 | 1 | 0 |
| 0 | 1 | 0 | 0 | 1 |
| 0 | 1 | 0 | 1 | 0 |
| 0 | 1 | 1 | 0 | 1 |
| 0 | 1 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 | 1 |
| 1 | 0 | 0 | 1 | 0 |
| 1 | 0 | 1 | 0 | 1 |
| 1 | 0 | 1 | 1 | 1 |
| 1 | 1 | 0 | 0 | 1 |
| 1 | 1 | 0 | 1 | 0 |
| 1 | 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 1 | 1 |

## Implementation of basic logic gates using only NOR gates

CSE1003  
Digital Logic and DesignModule 2  
BOOLEAN ALGEBRA L2Dr. S. Hemamalini  
ProfessorSchool of Electrical Engineering  
VIT Chennai

**Module 2**  
**BOOLEAN ALGEBRA** **8 hrs**

## Boolean algebra

- Properties of Boolean algebra
  - Boolean functions
  - Canonical and Standard forms
  - Logic gates - Universal gates
  - Karnaugh map - Don't care conditions
  - Tabulation Method

## Boolean Algebra

| Logic 0     | Logic 1       |
|-------------|---------------|
| False       | True          |
| Off         | On            |
| Low         | High          |
| No          | Yes           |
| Open switch | Closed switch |

1854  
George Boole

- Boolean algebra is mathematics of logic.
  - The algebra which deals with the logical operations of binary variables is called Boolean Algebra.
  - **Boolean algebra** is a means for expressing the relationship between a logic circuit's inputs and outputs.
  - The inputs are considered **logic variables** whose logic levels at any time determine the output levels.
  - It is one of the most basic tools available to the logic designer and thus can be effectively used for simplification of complex logic expressions.

## Boolean algebra

## Boolean functions

- Is an **expression** formed with binary variables, Boolean operators and the equality sign.
  - Can also be represented in the form of a truth table.

**Expression:** a set of literals (possibly with repeats) combined with logic operations (and possibly ordered by parentheses)

$$AB + C \quad (\bar{A} + B)C$$

**Equation:** expression1 = expression2

$$(\bar{A} + B)C = ((\bar{A}) + B)C$$

**Function of (possibly several) variables:** an equation where the left hand side is defined by the right hand side

$$f(A, B, C) = ((\bar{A}) + B) \cdot C$$

## Boolean algebra

## *Variables, Literals and Terms in Boolean Expressions*

- **Variables** are the letters in a Boolean expression which represents a physical quantity such as a voltage signal. They may take on the value '0' or '1'.
  - The complement of a variable is not considered as a separate variable. Each occurrence of a variable or its complement is called a **literal**.
  - A **term** is the expression formed by literals and operations at one level.

$$\overline{A} + A.B + A.\overline{C} + \overline{A}.B.C$$

$$(\overline{P} + Q).(R + \overline{S}).(P + \overline{O} + R)$$

$$\begin{array}{r} <5 \\ 72 \\ \hline 0.8 \end{array}$$

$$\begin{array}{c} A & B & C \\ \hline \bar{A} & \bar{B} & \bar{C} \end{array}$$

## BOOLEAN THEOREMS

- help to simplify logic expressions and logic circuits

### Single-variable theorems



**OR**



## Laws of Boolean Algebra

### ◆ Commutative Laws

$$A + B = B + A$$



$$A \cdot B = B \cdot A$$



### ◆ Associative Laws

$$A + (B + C) = (A + B) + C$$



$$A \cdot (B \cdot C) = (A \cdot B) \cdot C$$



### ◆ Distributive Law

$$A \cdot (B + C) = A \cdot B + A \cdot C$$

$$A \cdot (B + C) = A \cdot B + A \cdot C$$



## DeMorgan's Theorem

DeMorgan's theorems are extremely useful in simplifying expressions in which a product or sum of variables is inverted.

The complement of a product of variables is equal to the sum of the complements of the variables

$$\overline{XY} = \bar{X} + \bar{Y}$$



(a)

$\overline{xy} = \bar{x} + \bar{y}$

-V2 OR (b)

$\overline{x+y} = \overline{xy}$

(b)

$\overline{x+y} = \overline{xy}$

The complement of a sum of variables is equal to the product of the complements of the variables.

$$\overline{X+Y} = \bar{X} \cdot \bar{Y}$$

(a)

$\overline{x+y} = \bar{x} \cdot \bar{y}$

(b)

$\overline{x+y} = \bar{x} \cdot \bar{y}$

-V2 AND (b)

### Laws of Boolean Algebra used for simplifying logical expressions

$(A^l = \bar{A}$  denotes the complement/inverse/NOT of  $A$ )

$$A + 0 = A$$

$$(A^l)^l = A$$

$$A + 1 = A$$

$$A + AB = A$$

$$A \cdot 0 = 0$$

$$A + A^l B = A + B$$

$$A \cdot 1 = A$$

$$A + B = B + A$$

$$A + A = A$$

$$A \cdot B = B \cdot A$$

$$A + A^l = 1$$

$$\overline{A + B} = \overline{A} \cdot \overline{B}$$

$$A \cdot A = A$$

$$\overline{A \cdot B} = \overline{A} + \overline{B}$$

$$A \cdot A^l = 0$$

$$(A + B)(A + C) = A + BC$$

$$A \cdot B \cdot 1 = A \cdot B$$

$$A + B + 1 = 1$$

$$A \cdot B \cdot 0 = 0$$

$$A + B + 0 = A + B$$

### UNIVERSALITY OF NOR GATES



(a)



(b)



(c)



INVERTER



OR



AND

### UNIVERSALITY OF NAND GATES



43

### Precedence rules in Boolean algebra

- Scan the expression from left to right.
- First evaluate expression enclosed in parentheses.
- Perform all the complement operations.
- Perform all the AND operations in the order.
- Perform all the OR operations.

44

### DESCRIBING LOGIC CIRCUITS ALGEBRAICALLY FROM BOOLEAN EXPRESSIONS

A Boolean function from an algebraic expression can be realized to a logic diagram composed of logic gates.



### Determining output value from a logic diagram



### DESCRIBING LOGIC CIRCUITS ALGEBRAICALLY FROM BOOLEAN EXPRESSIONS



### Simplification Techniques

- The primary objective of all simplification procedures is to obtain an expression that has the minimum number of terms.
- Obtaining an expression with the minimum number of literals is usually the secondary objective.
- If there is more than one possible solution with the same number of terms, the one having the minimum number of literals is the choice.

Algebraic Method  
K - Map  
Tabulation

$$Y = (\cancel{ABC}) + (\cancel{A}BC) + (A\cancel{C}) + (A\cancel{B}C) + (\cancel{B}CA) + (BCA)$$

*4 term  
A + C*

### Simplify using Boolean Algebra

$$\begin{aligned} y &= \bar{A}\bar{B}D + A\bar{B}\bar{D} \rightarrow A\bar{B}(\bar{D} + \bar{D}) = A\bar{B} \quad \bar{D} + \bar{D} = 1 \\ z &= (\bar{A} + B)(A + B) \rightarrow z = B \quad \text{Simplification} \\ x &= ACD + \bar{A}BCD \rightarrow x = ACD + BCD \quad \text{Simplification} \\ z &= (\bar{A} + C)(B + \bar{D}) \rightarrow z = A\bar{C} + \bar{B}D \quad \text{Simplification} \\ &\quad \Rightarrow (\bar{A} + C) + (\bar{B} + D) = \bar{A} \cdot \bar{C} + \bar{B} \cdot \bar{D} = \bar{A}\bar{C} + \bar{B}D \end{aligned}$$

### Simplify using Boolean Algebra

Determine the output expression for the circuit below and simplify it using DeMorgan's Theorem



Simplify the logic circuit shown in Figure



## CSE1003 Digital Logic and Design

### Module 2 BOOLEAN ALGEBRA L3

Dr. S. Hemamalini

Professor

School of Electrical Engineering  
VIT Chennai

**Module 2  
BOOLEAN ALGEBRA      8 hrs**

**Boolean algebra**

- Properties of Boolean algebra
- Boolean functions
- Canonical and Standard forms
- Logic gates - Universal gates
- Karnaugh map - Don't care conditions
- Tabulation Method

**CANONICAL AND STANDARD FORMS**

- Sum of Products (SOP):** The logical sum of two or more logical product terms is referred to as a sum of products expression. It is basically an OR operation on AND operated variables. This form is also called the Disjunctive Normal Form (DNF).

$$Y = AB + BC + AC$$

$$Y = A'B + BC + AC'$$

- In a sum-of-products form, a single overbar cannot extend over more than one variable, although more than one variable in a term can have an overbar.
- For example,  $\overline{A} \overline{B} \overline{C}$  can be a term in sum-of-products expression but not  $\overline{ABC}$ .

$$Y = \overline{A'}B + \overline{B'}A$$

**CANONICAL AND STANDARD FORMS**

- An arbitrary logic function can be expressed in the following forms.

(i) Sum of the Products (SOP)

(ii) Product of the Sums (POS)

**Product Term:** In Boolean algebra, the logical product of several variables on which a function depends is considered to be a product term. In other words, the AND function is referred to as a product term or standard product.

**Sum Term:** The logical sum of several variables on which a function depends is considered to be a sum term. An OR function is referred to as a sum term.

$$f(A, B, C) = A + B + C$$

**Product of Sums (POS)**

- The logical product of two or more logical sum terms is called a product of sums expression.
- It is an AND operation on OR operated variables.
- This form is also called the Conjunctive Normal Form (CNF).

$$Y = (A + B + C)(A + B' + C)(A + B + C')$$

$$Y = (A + B + C)(A' + B' + C')$$

- In the product-of-sums (POS) expression, a single overbar cannot extend over more than one variable, although more than one variable in a term can have an overbar.
- For example, a product-of-sums (POS) expression can have the term  $\overline{A} + B + \overline{C}$  but not  $A + B + C$ .

## CANONICAL AND STANDARD FORMS

**Standard form:** The standard form of the Boolean function is when it is expressed in sum of the products or product of the sums fashion.

### Standard or Canonical Sum-of-products (SOP) Form

- If each term in the sum of products form contains all the variables (literals), then the expression is known as standard sum of products form or canonical sum of products form.
- In this form each product term contains all the variables of the function either in complemented or uncomplemented form.

$$f(A, B, C, D) = AB\bar{C}D + \bar{A}\bar{B}CD + \bar{A}B\bar{C}D$$

$$f(A, B) = AB + B =$$

### MINTERM

- Each of the product terms in the standard SOP form is called a minterm i.e., a product term which contains all the variables of the function either in complemented or uncomplemented form is called a minterm.

## MINTERM

- An  $n$  variable function can have in all  $2^n$  minterms. A minterm is equal to 1 for only one combination of variables.

$$f(A, B) = \bar{A}\bar{B} + \bar{A}B + A\bar{B} + AB =$$

For example the term  $\bar{A}\bar{B}D$  is equal to 1 only when  $A = 1, B = 0, C = 1$  and  $D = 0$ .

- The sum of the minterms whose value is equal to 1 is the standard sum of products form of the function.

- The minterms are often denoted as  $m_0, m_1, m_2, \dots$ , where the subscripts are the decimal equivalent of the binary number of the minterms.

- For minterms, the binary words are formed by representing each non-complemented variable by a 1 and each complemented variable by a 0.

For example, for the minterm  $\bar{A}\bar{B}C\bar{D}$  binary number is 1001 and decimal equivalent is 9. Hence it is represented as  $m_9$

$$\bar{A}\bar{B}C\bar{D}$$

## Minterms for 3 variables and their designation

0 - Complemented  
1 - Uncomplemented

### $\Sigma$ Notation

$\Sigma$  notation is used to represent sum-of-products Boolean expressions.

### Standard SOP form:

$$f(A, B, C) = \bar{A}\bar{B}C + \bar{A}\bar{B}\bar{C} + \bar{A}BC + A\bar{B}\bar{C}$$

Another way of representing the function in canonical SOP form is by showing the sum of minterms for which the function value equals 1.

$$f(A, B, C) = m_1 + m_2 + m_3 + m_5$$

$$f(A, B, C) = \sum m(1, 2, 3, 5)$$

| A | B | C | Minterm                 | Designation |
|---|---|---|-------------------------|-------------|
| 0 | 0 | 0 | $\bar{A}\bar{B}\bar{C}$ | $m_0$       |
| 0 | 0 | 1 | $\bar{A}\bar{B}C$       | $m_1$       |
| 0 | 1 | 0 | $\bar{A}B\bar{C}$       | $m_2$       |
| 0 | 1 | 1 | $\bar{A}BC$             | $m_3$       |
| 1 | 0 | 0 | $A\bar{B}\bar{C}$       | $m_4$       |
| 1 | 0 | 1 | $A\bar{B}C$             | $m_5$       |
| 1 | 1 | 0 | $AB\bar{C}$             | $m_6$       |
| 1 | 1 | 1 | $ABC$                   | $m_7$       |

Another way of representing the function in canonical form is by listing the decimal equivalents of the minterms for which  $f = 1$ .

## Standard product of sum (POS) form

- Maxterm:** A sum term which contains each of the  $n$  variables in either complemented or uncomplemented form is called a maxterm.

### Maxterms for 3 variables and their designation

| A | B | C | Maxterm                       | Designation |
|---|---|---|-------------------------------|-------------|
| 0 | 0 | 0 | $A + B + C$                   | $M_0$       |
| 0 | 0 | 1 | $A + B + \bar{C}$             | $M_1$       |
| 0 | 1 | 0 | $A + \bar{B} + C$             | $M_2$       |
| 0 | 1 | 1 | $A + \bar{B} + \bar{C}$       | $M_3$       |
| 1 | 0 | 0 | $\bar{A} + B + C$             | $M_4$       |
| 1 | 0 | 1 | $\bar{A} + B + \bar{C}$       | $M_5$       |
| 1 | 1 | 0 | $\bar{A} + \bar{B} + C$       | $M_6$       |
| 1 | 1 | 1 | $\bar{A} + \bar{B} + \bar{C}$ | $M_7$       |

$$f(A, B, C) = (\bar{A} + B + C)(A + \bar{B} + C)$$

maxterm

## Maxterms

1. For an  $n$ -variable function, there will be at the most  $2^n$  maxterms. A maxterm assumes the value 0 only for one combination of the variables.

For example, the term  $A + B + C + D$  is 0 only when  $A = 0, B = 1, C = 0$  and  $D = 1$ . For all other combinations it will be 1.

2. The product of maxterms whose value is 0 gives the standard or canonical product of sums form of the function.

3. Maxterms are often represented as  $M_0, M_1, M_2, \dots$ , where the subscripts denote decimal equivalent of the binary number of the maxterms.

4. For maxterms, the binary words are formed by representing each non-complemented variable by a 0 and each complemented variable by a 1.

For example, for the maxterm  $A + B + C + D$  binary number is 0110 and decimal equivalent is 6. Hence, it is represented as  $M_6$ .

## CONVERTING EXPRESSIONS TO STANDARD SOP OR POS FORMS

### Converting SOP Form to Standard SOP Form

- Find the missing literal in each product term if any.
- If one or more variables are missing in any term, expand that term by multiplying it with the sum of each one of the missing variables and its complement.

For example, in a three variable SOP function consider a term  $AB'$ . The third variable  $C$  is missing. So, to convert it into standard form multiply the term by  $(C + C')$  and expand it as  $AB(C + C') = AB'C + AB'C'$

- Remove repeated product terms if any.

$$f(A, B) = A (B + B')$$

## Standard product of sum (POS) form

- $\Pi$  Notation

Standard POS form:

$$f(A, B, C) = (A + B + C)(\bar{A} + B + C)(\bar{A} + \bar{B} + C)(\bar{A} + \bar{B} + \bar{C})$$

Another way of representing the function in canonical POS form is by showing the product of maxterms for which the function value equals 0.

$$f(A, B, C) = M_0 \cdot M_4 \cdot M_6 \cdot M_7$$

Another way of representing the function in canonical POS form is by listing the decimal equivalents of the maxterms for which  $f=0$ .

$$f(A, B, C) = \Pi(0, 4, 6, 7)$$

## Converting POS Form to standard POS Form

- Find the missing literals in each sum term if any.
- If one or more variables are missing in any sum term, expand that term by adding the products of each of the missing variable and its complement.
- For expanding, apply rule  $A + BC = (A + B)(A + C)$ . For example, in a three variable POS function consider a term  $A + B'$ . The third variable  $C$  is missing. So, to convert it into standard form add the term  $(CC')$  and expand it as  $A + B' + CC' = (A + B' + C)(A + B' + C')$ .
- Remove repeated sum terms if any.

$$f(A, B, C) = (A + B') + C C' = \underline{\underline{(A + B') + C}} \underline{\underline{(A + B' + C)}}$$

Simplifying logic circuit

$$\begin{aligned}
 Z &= ABC + A\bar{B} \cdot (\bar{A}\bar{C}) = ABC + A\bar{B}(\bar{A} + \bar{C}) \\
 &= ABC + A\bar{B}(A+C) = ABC + A\bar{B}A + A\bar{B}C \\
 &= ABC + A\bar{B} + A\bar{B}C = AC(B+\bar{B}) + A\bar{B} \\
 &= AC + A\bar{B} = A(C + \bar{B})
 \end{aligned}$$

CSE1003

Digital Logic and Design

Module 2  
BOOLEAN ALGEBRA L4

Dr. S. Hemamalini

Professor

School of Electrical Engineering  
VIT Chennai

**Module 2**  
**BOOLEAN ALGEBRA    8 hrs**

**Boolean algebra**

- Properties of Boolean algebra
- Boolean functions
- Canonical and Standard forms
- Logic gates - Universal gates
- Karnaugh map - Don't care conditions
- Tabulation Method

**Minimization of Boolean expressions**

- The minimization will result in reduction of
  - the number of gates (resulting from less number of terms)
  - the number of inputs per gate (resulting from less number of variables per term)
- Reduced cost
- Improved efficiency
- Reduced power consumption

**Simplification Techniques**

- Primary objective - to obtain an expression that has the minimum number of terms.
- Secondary objective - obtaining an expression with the minimum number of literals
- If there is more than one possible solution with the same number of terms, the one having the minimum number of literals is the choice.

**Sum-of-Products Boolean Expressions**

- A sum-of-products expression contains the sum of different terms, with each term being either a single literal or a product of more than one literal.
- It can be obtained from the truth table directly by considering those input combinations that produce a logic '1' at the output.
- Each such input combination produces a term.
- Different terms are given by the product of the corresponding literals.
- The sum of all terms gives the expression.

| A | B | C | Y |
|---|---|---|---|
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 0 |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 1 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 0 |

$$Y = \overline{A} \cdot \overline{B} \cdot \overline{C} + \overline{A} \cdot B \cdot C + A \cdot \overline{B} \cdot \overline{C} + A \cdot \overline{B} \cdot C$$

## Minimum SOP

- The minimum sum of products (MSOP) of a function,  $f$ , is a SOP representation of  $f$  that contains the fewest number of product terms and fewest number of literals of any SOP representation of  $f$ .
- $f = (xyz + x'yz + xy'z + \dots)$  is called sum of products.
- The  $+$  is sum operator which is an OR gate.
- The product such as  $xy$  is an AND gate for the two inputs  $x$  and  $y$ .
- A minimum SOP expression can be implemented with fewer logic gates than a standard expression.

## Simplification using Boolean Algebra

- Algebraic method**
- Karnaugh Map**
- Tabulation Method**
- Algebraic method**
  - Put the given expression in the SOP form repeatedly using DeMorgan's theorems and multiplication of terms.
  - Check the product terms for common variables and perform factoring wherever possible. This mostly results in elimination of one or more terms.
  - No guarantee that the reduced expression will be a minimal.

## Minimum product of sums (MPOS)

- The minimum product of sums (MPOS) of a function,  $f$ , is a POS representation of  $f$  that contains the fewest number of sum terms and the fewest number of literals of any POS representation of  $f$ .
- The zeros are considered exactly the same as ones in the case of sum of product (SOP)

## Karnaugh Map (K-Map)

- Used to simplify a Boolean expression to their minimal form.
- K-Map method is a pictorial arrangement of the truth table which allows minimal literals to express the function algebraically.
- K-Map method can be applied to functions up to 6 variables only.
- For more than 6 variables, Quine- McClusky method is used.
- K-Map is an array of cells in which each cell represents a binary value of the input variables.
- The cells are arranged in such a way that simplification of a given expression is based on properly grouping the cells.
- K-Map for an  $n$ -variable Boolean function is a rectangular diagram in which the  $2^n$  minterms of the given function are arranged in  $2^n$  squares in such an order that the minterms in the adjacent squares differ only by one variable, which is complemented in one square and uncomplemented in the other.

## Karnaugh Map

- Is a graphical or pictorial representation of a truth table.
- A **minterm** of  $n$  variables is a product of  $n$  literals in which each variable appears exactly once in either true or complemented form, but not both.
- A **maxterm** of  $n$  variables is a sum of  $n$  literals in which each variable appears exactly once in either true or complemented form, but not both.

| Row No. | A | B | C | Minterms       | Maxterms             |
|---------|---|---|---|----------------|----------------------|
| 0       | 0 | 0 | 0 | $A'B'C' = m_0$ | $A + B + C = M_0$    |
| 1       | 0 | 0 | 1 | $A'B'C = m_1$  | $A + B + C' = M_1$   |
| 2       | 0 | 1 | 0 | $A'BC' = m_2$  | $A + B' + C = M_2$   |
| 3       | 0 | 1 | 1 | $A'BC = m_3$   | $A + B' + C' = M_3$  |
| 4       | 1 | 0 | 0 | $AB'C' = m_4$  | $A' + B + C = M_4$   |
| 5       | 1 | 0 | 1 | $AB'C = m_5$   | $A' + B + C' = M_5$  |
| 6       | 1 | 1 | 0 | $ABC' = m_6$   | $A' + B' + C = M_6$  |
| 7       | 1 | 1 | 1 | $ABC = m_7$    | $A' + B' + C' = M_7$ |

- If  $m_i$  is a minterm of  $f$ , then place a 1 in cell  $i$  of the K-map.
- If  $M_i$  is a maxterm of  $f$ , then place a 0 in cell  $i$ .

## General structure of K-maps



(a) Two variable K-map



(b) Three variable K-Map



(c) Four variable K-map

## K-Map Procedure

- Prepare a blank map with  $2^n$  cells ( $n$ - no. of variables) labelled with the variables appropriately.
- Enter a '1' in each cell (or square) of those minterms for which  $F=1$ .
- Enter a '0' in each of the remaining cells.
- Identify the possible pairs of adjacent 1's (horizontally or vertically) and group them together, so that maximum 1's can be grouped into pairs.
  - Bigger groups with eight 1's called octets
  - Bigger groups with four 1's called quads
  - Leave the isolated 1's
  - Any 1 can be reused in this process and the groups can overlap.
- Write down the terms related with each group of 1's as well as each isolated 1, by multiplying the variables and ordinate of that group or isolated 1 and ignoring the variable which appear in both the complemented and uncomplemented forms ( $A$  &  $A'$ )
- Sum up all these terms to get the minimal expression of the function.



Two variable K-map  $f(A,B)=\Sigma m(0,1,3)=A'B'+A'B+AB$



*SOP*

| $\bar{A}$ | $\bar{B}$ | $C$ | $\bar{C}$ | $C$ |
|-----------|-----------|-----|-----------|-----|
| 0         | 0         | 0   | 1         | 1   |
| 0         | 0         | 1   | 0         | 0   |
| 0         | 1         | 0   | 0         | 1   |
| 0         | 1         | 1   | 0         | 0   |
| 1         | 0         | 0   | 0         | 0   |
| 1         | 0         | 1   | 0         | 1   |
| 1         | 1         | 0   | 1         | 0   |
| 1         | 1         | 1   | 1         | 1   |

### K-Map for 3 variables

| $A$ | $B$ | $C$ | X               |
|-----|-----|-----|-----------------|
| 0   | 0   | 0   | 1 → $\bar{ABC}$ |
| 0   | 0   | 1   | 1 → $\bar{ABC}$ |
| 0   | 1   | 0   | 1 → $\bar{ABC}$ |
| 0   | 1   | 1   | 0               |
| 1   | 0   | 0   | 0               |
| 1   | 0   | 1   | 0               |
| 1   | 1   | 0   | 1 → $ABC$       |
| 1   | 1   | 1   | 0               |

$$X = \bar{ABC} + \bar{ABC} + ABC$$

| $\bar{A}$ | $\bar{B}$ | $\bar{C}$ | $C$ |
|-----------|-----------|-----------|-----|
| 0         | 1         | 1         | 1   |
| 0         | 1         | 0         | 0   |
| 1         | 0         | 1         | 0   |
| 1         | 0         | 0         | 0   |

### K-Map for 4 variables

| $A$ | $B$ | $C$ | $D$ | X                |
|-----|-----|-----|-----|------------------|
| 0   | 0   | 0   | 0   | 0                |
| 0   | 0   | 0   | 1   | 1 → $\bar{ABCD}$ |
| 0   | 0   | 1   | 0   | 0                |
| 0   | 0   | 1   | 1   | 0                |
| 0   | 1   | 0   | 0   | 0                |
| 0   | 1   | 0   | 1   | 1 → $\bar{ABCD}$ |
| 0   | 1   | 1   | 0   | 0                |
| 0   | 1   | 1   | 1   | 0                |
| 1   | 0   | 0   | 0   | 0                |
| 1   | 0   | 0   | 1   | 0                |
| 1   | 0   | 1   | 0   | 0                |
| 1   | 0   | 1   | 1   | 0                |
| 1   | 1   | 0   | 0   | 1 → $AB\bar{CD}$ |
| 1   | 1   | 0   | 1   | 0                |
| 1   | 1   | 1   | 0   | 0                |
| 1   | 1   | 1   | 1   | 1 → $ABCD$       |

$$X = \bar{ABCD} + \bar{ABC}D + ABCD + AB\bar{CD}$$

| $\bar{A}$ | $\bar{B}$ | $\bar{C}$ | $\bar{D}$ | $\bar{CD}$ |
|-----------|-----------|-----------|-----------|------------|
| 0         | 1         | 0         | 0         | 0          |
| 0         | 1         | 0         | 1         | 0          |
| 0         | 1         | 1         | 1         | 1          |
| 1         | 0         | 1         | 0         | 0          |
| 1         | 0         | 1         | 1         | 1          |
| 1         | 1         | 0         | 0         | 0          |
| 1         | 1         | 0         | 1         | 0          |
| 1         | 1         | 1         | 0         | 0          |

### K-Map for 4 variables

| $\bar{A}$ | $\bar{B}$ | $\bar{C}$  | $\bar{D}$ | 00       | 01        | 11 | 10 |
|-----------|-----------|------------|-----------|----------|-----------|----|----|
| 0         | 0         | $A'B'C'D'$ | $A'B'C'D$ | $A'B'CD$ | $A'B'CD'$ |    |    |
| 0         | 1         | $A'BC'D'$  | $A'BC'D$  | $A'BCD$  | $A'BCD'$  |    |    |
| 1         | 0         | $ABC'D'$   | $ABC'D$   | $ABCD$   | $ABCD'$   |    |    |
| 1         | 1         | $AB'C'D'$  | $AB'C'D$  | $AB'CD$  | $AB'CD'$  |    |    |

| $\bar{A}$ | $\bar{B}$ | $\bar{C}$ | $\bar{D}$ | 00       | 01       | 11 | 10 |
|-----------|-----------|-----------|-----------|----------|----------|----|----|
| 0         | 0         | $m_0$     | $m_1$     | $m_2$    | $m_3$    |    |    |
| 0         | 1         | $m_4$     | $m_5$     | $m_6$    | $m_7$    |    |    |
| 1         | 0         | $m_{12}$  | $m_{13}$  | $m_{14}$ | $m_{15}$ |    |    |
| 1         | 1         | $m_8$     | $m_9$     | $m_{10}$ | $m_{11}$ |    |    |

### Simplification Guidelines for K-maps

- Always combine as many cells in a group as possible. This will result in the fewest number of literals in the term that represents the group.
- Make as few groupings as possible to cover all minterms. This will result in the fewest product terms.
- Always begin with the largest group, which means if you can find eight members group is better than two four groups and one four group is better than pair of two-group.

## Adjacency

- Cell adjacency
  - Only one variable changes from complemented to uncomplemented form or vice-versa moving from one square to the other in the rows or columns.
- Wrap around adjacency
  - The cells in the top row are adjacent to the corresponding cells in the bottom row and the cells in the outer left column are adjacent to the corresponding cells in the outer right column.

## Grouping Cells (Pair)

| C          | $\bar{C}$ | C |
|------------|-----------|---|
| AB         | 0         | 0 |
| $\bar{A}B$ | 1         | 0 |
| AB         | 1         | 0 |
| $A\bar{B}$ | 0         | 0 |

$$X = \bar{A}\bar{B} + A\bar{B}$$

$$= \bar{B}$$

| C          | $\bar{C}$ | C |
|------------|-----------|---|
| AB         | 0         | 0 |
| $\bar{A}B$ | 1         | 0 |
| AB         | 0         | 0 |
| $A\bar{B}$ | 0         | 0 |

$$X = \bar{A}\bar{B} + \bar{A}B$$

$$= \bar{A}$$

| C          | $\bar{C}$ | C |
|------------|-----------|---|
| AB         | 0         | 0 |
| $\bar{A}B$ | 0         | 0 |
| AB         | 0         | 0 |
| $A\bar{B}$ | 1         | 0 |

$$X = \bar{A}\bar{C} + A\bar{C}$$

$$= \bar{C}$$

| CD         | $\bar{C}\bar{D}$ | $\bar{C}D$ | CD | $C\bar{D}$ |
|------------|------------------|------------|----|------------|
| AB         | 0                | 0          | 1  | 1          |
| $\bar{A}B$ | 0                | 0          | 0  | 0          |
| AB         | 0                | 0          | 0  | 0          |
| $A\bar{B}$ | 1                | 0          | 0  | 1          |

$$X = \bar{A}\bar{C}\bar{D} + \bar{A}\bar{C}D + A\bar{C}\bar{D} + A\bar{C}D$$

$$= \bar{A}C + ABD$$

Looping a pair of adjacent 1s in a K map eliminates the variable that appears in complemented and uncomplemented form.

## K-map method for simplifying a Boolean expression – step by step procedure

1. Construct the K-map as discussed. Enter 1 in those cells corresponding to the minterms for which function value is 1. Place 0's in other cells.
2. Form the groups of possible 1s as pair, quad and octet. There can be overlapping of groups if they include common cells. While doing this make sure that there are minimum number of groups.
3. Encircle the cells which contain 1s and are not adjacent to any other cell. These are known as isolated minterms and they appear in the expression in same form.
4. Avoid any redundant group.
5. Write the Boolean term for each group and obtain the minimized expression by summing product terms of all the groups.

A K map may contain a group of four 1s that are adjacent to each other. This group is called a *quad*.

| C          | $\bar{C}$ |   |
|------------|-----------|---|
| AB         | 0         | 1 |
| $\bar{A}B$ | 0         | 1 |
| AB         | 0         | 1 |
| $A\bar{B}$ | 0         | 1 |

| CD         | $\bar{C}\bar{D}$ | $\bar{C}D$ | CD | $C\bar{D}$ |
|------------|------------------|------------|----|------------|
| AB         | 0                | 0          | 0  | 0          |
| $\bar{A}B$ | 0                | 0          | 0  | 0          |
| AB         | 1                | 1          | 1  | 1          |
| $A\bar{B}$ | 0                | 1          | 1  | 0          |

$$X = C$$

$$X = AB$$

| CD         | $\bar{C}\bar{D}$ | $\bar{C}D$ | CD | $C\bar{D}$ |
|------------|------------------|------------|----|------------|
| AB         | 0                | 0          | 0  | 0          |
| $\bar{A}B$ | 0                | 0          | 0  | 0          |
| AB         | 1                | 0          | 0  | 1          |
| $A\bar{B}$ | 1                | 0          | 0  | 1          |

$$X = C$$

$$X = BD$$

Looping a quad of adjacent 1s eliminates the two variables that appear in both complemented and uncomplemented form.

| CD         | $\bar{C}\bar{D}$ | $\bar{C}D$ | CD | $C\bar{D}$ |
|------------|------------------|------------|----|------------|
| AB         | 1                | 0          | 0  | 1          |
| $\bar{A}B$ | 0                | 0          | 0  | 0          |
| AB         | 0                | 0          | 0  | 0          |
| $A\bar{B}$ | 1                | 0          | 0  | 1          |

$$X = \bar{B}\bar{D}$$

## Groups of Eight (Octets)

A group of eight 1s that are adjacent to one another is called an *octet*.

|                  | CD | $\bar{C}D$ | $\bar{C}\bar{D}$ | CD | C $\bar{D}$ |  |
|------------------|----|------------|------------------|----|-------------|--|
| AB               | 0  | 0          | 0                | 0  | 0           |  |
| $\bar{A}B$       | 1  | 1          | 1                | 1  | 1           |  |
| AB               | 1  | 1          | 1                | 1  | 1           |  |
| $\bar{A}\bar{B}$ | 0  | 0          | 0                | 0  | 0           |  |

$$X = B$$

$$X = \bar{C}$$

|                  | CD | $\bar{C}D$ | CD | $\bar{C}\bar{D}$ |  |
|------------------|----|------------|----|------------------|--|
| AB               | 1  | 1          | 0  | 0                |  |
| $\bar{A}B$       | 1  | 1          | 0  | 0                |  |
| AB               | 1  | 1          | 0  | 0                |  |
| $\bar{A}\bar{B}$ | 1  | 1          | 0  | 0                |  |

$$X = \bar{C}$$

$$X = \bar{B}$$

$$X = \bar{D}$$

Looping an octet of adjacent 1s eliminates the three variables that appear in both complemented and uncomplemented form.

When a variable appears in both complemented and uncomplemented form within a loop, that variable is eliminated from the expression.

Variables that are the same for all squares of the loop must appear in the final expression.

## Module 2 BOOLEAN ALGEBRA 8 hrs

### Boolean algebra

- Properties of Boolean algebra
- Boolean functions
- Canonical and Standard forms
- Logic gates - Universal gates
- Karnaugh map - Don't care conditions
- Tabulation Method

## CSE1003 Digital Logic and Design

### Module 2 BOOLEAN ALGEBRA L5

Dr. S. Hemamalini

Professor

School of Electrical Engineering  
VIT Chennai

### K-map method for simplifying a Boolean expression – step by step procedure

1. Construct the K-map as discussed. Enter 1 in those cells corresponding to the minterms for which function value is 1. Place 0's in other cells.
2. Form the groups of possible 1s as pair, quad and octet. There can be overlapping of groups if they include common cells. While doing this make sure that there are minimum number of groups.
3. Encircle the cells which contain 1s and are not adjacent to any other cell. These are known as isolated minterms and they appear in the expression in same form.
4. Avoid any redundant group.
5. Write the Boolean term for each group and obtain the minimized expression by summing product terms of all the groups.

## Grouping Cells (Pair)

|                  | C | $\bar{C}$ | C |
|------------------|---|-----------|---|
| AB               | 0 | 0         |   |
| $\bar{A}B$       | 1 | 0         |   |
| AB               | 1 | 0         |   |
| $\bar{A}\bar{B}$ | 0 | 0         |   |

|                  | C | $\bar{C}$ | C |
|------------------|---|-----------|---|
| AB               | 0 | 0         |   |
| $\bar{A}B$       | 0 | 0         |   |
| AB               | 0 | 0         |   |
| $\bar{A}\bar{B}$ | 0 | 0         |   |

Cell adjacency



|                  | CD | $\bar{C}\bar{D}$ | $\bar{C}D$ | CD | $C\bar{D}$ |
|------------------|----|------------------|------------|----|------------|
| AB               | 0  | 0                | 0          | 1  | 1          |
| $\bar{A}B$       | 0  | 0                | 0          | 0  | 0          |
| AB               | 0  | 0                | 0          | 0  | 0          |
| $\bar{A}\bar{B}$ | 1  | 0                | 0          | 0  | 1          |

$$X = \bar{A}\bar{B}\bar{C} + A\bar{B}\bar{C}$$

$$= BC$$

$$X = \bar{A}\bar{B}\bar{C} + \bar{A}BC$$

$$= \bar{A}B$$

$$X = \bar{A}BC + ABC = \bar{B}C$$

$$X = \bar{A}\bar{B}\bar{C}\bar{D} + \bar{A}\bar{B}\bar{C}D + \bar{A}\bar{B}C\bar{D} + \bar{A}B\bar{C}\bar{D}$$

$$= \bar{A}BC + ABD$$

Looping a pair of adjacent 1s in a K map eliminates the variable that appears in complemented and uncomplemented form.

## Groups of Four (Quads)

A K map may contain a group of four 1s that are adjacent to each other. This group is called a quad.

|                  | C | $\bar{C}$ | C |
|------------------|---|-----------|---|
| AB               | 0 | 1         |   |
| $\bar{A}B$       | 0 | 1         |   |
| AB               | 0 | 1         |   |
| $\bar{A}\bar{B}$ | 0 | 1         |   |

$$X = C$$

|                  | CD | $\bar{C}\bar{D}$ | $\bar{C}D$ | CD | $C\bar{D}$ |
|------------------|----|------------------|------------|----|------------|
| AB               | 0  | 0                | 0          | 0  | 0          |
| $\bar{A}B$       | 0  | 0                | 0          | 0  | 0          |
| AB               | 1  | 1                | 1          | 1  | 0          |
| $\bar{A}\bar{B}$ | 0  | 0                | 0          | 0  | 0          |

$$X = AB$$

|                  | CD | $\bar{C}\bar{D}$ | $\bar{C}D$ | CD | $C\bar{D}$ |
|------------------|----|------------------|------------|----|------------|
| AB               | 0  | 0                | 0          | 0  | 0          |
| $\bar{A}B$       | 0  | 0                | 0          | 0  | 0          |
| AB               | 1  | 1                | 1          | 1  | 0          |
| $\bar{A}\bar{B}$ | 0  | 0                | 0          | 0  | 0          |

$$X = BD$$

|                  | CD | $\bar{C}\bar{D}$ | $\bar{C}D$ | CD | $C\bar{D}$ |
|------------------|----|------------------|------------|----|------------|
| AB               | 0  | 0                | 0          | 0  | 0          |
| $\bar{A}B$       | 0  | 0                | 0          | 0  | 0          |
| AB               | 1  | 1                | 1          | 1  | 0          |
| $\bar{A}\bar{B}$ | 0  | 0                | 0          | 0  | 0          |

$$X = \bar{B}\bar{D}$$

Looping a quad of adjacent 1s in a K map eliminates the two variables that appear in both complemented and uncomplemented form.

## Groups of Eight (Octets)

A group of eight 1s that are adjacent to one another is called an octet.

|                  | CD | $\bar{C}\bar{D}$ | $\bar{C}D$ | CD | $C\bar{D}$ |
|------------------|----|------------------|------------|----|------------|
| AB               | 0  | 0                | 0          | 0  | 0          |
| $\bar{A}B$       | 0  | 0                | 0          | 0  | 0          |
| AB               | 0  | 0                | 0          | 0  | 0          |
| $\bar{A}\bar{B}$ | 1  | 0                | 0          | 0  | 1          |

|                  | $\bar{C}\bar{D}$ | $\bar{C}D$ | CD | $C\bar{D}$ |
|------------------|------------------|------------|----|------------|
| AB               | 0                | 0          | 0  | 0          |
| $\bar{A}B$       | 1                | 1          | 1  | 1          |
| AB               | 1                | 1          | 0  | 0          |
| $\bar{A}\bar{B}$ | 0                | 0          | 0  | 0          |

|                  | $\bar{C}\bar{D}$ | $\bar{C}D$ | CD | $C\bar{D}$ |
|------------------|------------------|------------|----|------------|
| AB               | 1                | 1          | 1  | 1          |
| $\bar{A}B$       | 0                | 0          | 0  | 0          |
| AB               | 1                | 1          | 0  | 0          |
| $\bar{A}\bar{B}$ | 0                | 0          | 0  | 0          |

|                  | $\bar{C}\bar{D}$ | $\bar{C}D$ | CD | $C\bar{D}$ |
|------------------|------------------|------------|----|------------|
| AB               | 1                | 0          | 0  | 1          |
| $\bar{A}B$       | 1                | 0          | 0  | 1          |
| AB               | 1                | 0          | 0  | 1          |
| $\bar{A}\bar{B}$ | 1                | 0          | 0  | 1          |

$$X = B$$

$$X = \bar{C}$$

$$X = \bar{B}$$

$$X = \bar{D}$$

Looping an octet of adjacent 1s eliminates the three variables that appear in both complemented and uncomplemented form.

When a variable appears in both complemented and uncomplemented form within a loop, that variable is eliminated from the expression.

Variables that are the same for all squares of the loop must appear in the final expression.



## Mapping a non-standard SOP expression

If an expression is not in standard form then it must be converted into standard form by numerical expansion of a non-standard product term.



Draw the Karnaugh map for  $\bar{Y} = AB + AB\bar{D}$ , and then use it to obtain a minimised expression.

$$\begin{aligned}
 Y &= \bar{C}(\bar{A}\bar{B}\bar{D} + D) + A\bar{B}C + \bar{D} \\
 &= \bar{A}\bar{B}\bar{C}\bar{D} + \bar{C}D + A\bar{B}C + \bar{D} \\
 &= \bar{A}\bar{B}\bar{C}\bar{D} + \bar{C}D + A\bar{B}C + \bar{D}
 \end{aligned}$$

Karnaugh map for  $\bar{Y} = AB + AB\bar{D}$ :

|    |      |      |      |      |   |
|----|------|------|------|------|---|
| AB | 00   | 01   | 10   | 11   | D |
| 00 | 0000 | 0010 | 0000 | 0010 | 0 |
| 01 | 0010 | 0110 | 0010 | 0110 | 1 |
| 10 | 0000 | 0010 | 0000 | 0010 | 1 |
| 11 | 0010 | 0110 | 0010 | 0110 | 1 |

Minimized expression:  $Y = A\bar{B} + \bar{C} + \bar{D}$

## K-map simplification of SOP expressions

- Grouping the cells that have 1s.
- Determine the minimum product term for each group.
- Sum the product term to get the minimum SOP expression.

Reduce this expression

$$f = \bar{A}\bar{B} + \bar{A}B + A\bar{B} = \bar{A} + B$$

$$f = m_0 + m_1 + m_3$$

$$f = \sum m(0, 1, 3)$$



$$\text{Eq. } f = \sum m(0, 2, 3, 4, 5, 6)$$

3 Variables

$$f = \bar{C} + \bar{A}B + A\bar{B}$$



## CSE1003 Digital Logic and Design

### Module 2 BOOLEAN ALGEBRA L6

Dr. S. Hemamalini

Professor

School of Electrical Engineering  
VIT Chennai

## Module 2 BOOLEAN ALGEBRA

**8 hrs**

**Boolean algebra**

- Properties of Boolean algebra
- Boolean functions
- Canonical and Standard forms
- Logic gates - Universal gates
- Karnaugh map - Don't care conditions
- Tabulation Method

**Plotting a Truth Table on K-map**

A truth table and corresponding SOP K-map

| Inputs |   | Output |
|--------|---|--------|
| A      | B | C      |
| 0      | 0 | 0      |
| 0      | 0 | 1      |
| 0      | 1 | 0      |
| 0      | 1 | 1      |
| 1      | 0 | 0      |
| 1      | 0 | 1      |
| 1      | 1 | 0      |
| 1      | 1 | 1      |



Represent the following Boolean function by K-map:

$$F(A, B, C, D) = ABC + \overline{B}CD + BD \rightarrow \text{non standard form}$$

$$\begin{aligned} F(A, B, C, D) &= ABC(D + \overline{D}) + \overline{B}CD(A + \overline{A}) + BD(A + \overline{A})(C + \overline{C}) \\ &= ABCD + ABC\overline{D} + A\overline{B}CD + \overline{A}BCD + ABCD \end{aligned}$$



$$f = CD + BD + ABC$$

**K-map For POS Expression**

Represent the following Boolean expression by K-map:

$$Y(A, B, C, D) = (A + B + \overline{C})(\overline{A} + C + \overline{D}) \rightarrow \text{non standard form}$$

$$\begin{aligned} Y(A, B, C, D) &= (A + B + \overline{C} + D\overline{D})(\overline{A} + C + \overline{D} + B\overline{B}) \\ &= (A + B + \overline{C} + D)(A + B + \overline{C} + \overline{D})(\overline{A} + B + C + \overline{D}) \end{aligned}$$



$$Y(A, B, C, D) = (\overline{A} + C + \overline{D})(A + B + \overline{C})$$

A truth table and corresponding POS K-map

| Inputs |   |   | Output |
|--------|---|---|--------|
| A      | B | C | Y      |
| 0      | 0 | 0 | 0      |
| 0      | 0 | 1 | 0      |
| 0      | 1 | 0 | 1      |
| 0      | 1 | 1 | 0      |
| 1      | 0 | 0 | 1      |
| 1      | 0 | 1 | 1      |
| 1      | 1 | 0 | 0      |
| 1      | 1 | 1 | 1      |

**Writing K-map**

Minimize the following expression in the POS form

$$\begin{aligned} F(A, B, C, D) &= (\overline{A} + \overline{B} + C + D)(\overline{A} + \overline{B} + \overline{C} + D) \\ &\quad (\overline{A} + \overline{B} + \overline{C} + D)(\overline{A} + B + C + D) \\ &\quad (A + \overline{B} + \overline{C} + D)(A + \overline{B} + \overline{C} + \overline{D}) \\ &\quad (A + B + C + D)(\overline{A} + \overline{B} + C + D) \end{aligned}$$

$$1100 \quad \overline{A} + \overline{B} + C + D$$

$$1110 \quad \overline{A} + \overline{B} + \overline{C} + D$$

$$1111 \quad \overline{A} + \overline{B} + \overline{C} + \overline{D}$$

$$1000 \quad \overline{A} + B + C + D$$

$$0110 \quad A + \overline{B} + \overline{C} + D$$

$$0111 \quad A + \overline{B} + \overline{C} + \overline{D}$$

$$0000 \quad A + B + C + D$$

↓  
1101



$$F(A, B, C, D) = (B + C + D)(\overline{B} + \overline{C})(\overline{A} + \overline{B})$$

## Don't-Care Conditions

- Some logic circuits can be designed so that there are certain input conditions for which there are no specified output levels, usually because these input conditions will never occur.
- There will be certain combinations of input levels where we "don't care" whether the output is HIGH or LOW.
- A circuit designer is free to make the output for any don't-care condition either a 0 or a 1 to produce the simplest output expression.



## Example for Don't-Care Conditions

Design a logic circuit that controls an elevator door in a three-storey building. The circuit in Figure has four inputs.  $M$  is a logic signal that indicates when the elevator is moving ( $M = 1$ ) or stopped ( $M = 0$ ).  $F_1$ ,  $F_2$ , and  $F_3$  are floor indicator signals that are normally LOW, and they go HIGH only when the elevator is positioned at the level of that particular floor. For example, when the elevator is lined up level with the second floor,  $F_2 = 1$  and  $F_1 = F_3 = 0$ . The circuit output is the OPEN signal, which is normally LOW and will go HIGH when the elevator door is to be opened.



## K-Map

### Advantages:

- K mapping is a more orderly process with well-defined steps compared with the trial-and-error process sometimes used in algebraic simplification.
- K mapping usually requires fewer steps, especially for expressions containing many terms, and it always produces a minimum expression.

### Limitations:

- K-maps are not suitable when the number of variables involved exceed four.
- It may be used with difficulty up to five and six variable systems. But, beyond 'six variables' K-maps cannot be physically visualized.
- K-map simplification is a manual technique and simplification process is heavily dependent on the abilities of the designer. It cannot be programmed.

Map the following expression on a K-Map.

$$F = \bar{A} + A\bar{B} + AB\bar{C}$$

|      | AB | C  |   |
|------|----|----|---|
| M    | 00 | 01 |   |
| F1   | 00 | 01 | X |
| M F1 | 01 | X  | X |
| M F1 | 10 | X  | X |
| M F1 | 11 | X  | X |

II term  $A\bar{B} \rightarrow C$  can be either '0' or 1  
possible combinations: 100 or 101

I term  $\bar{A} \rightarrow B, C$  are not given  
they may take values  
at 00, 01, 10, 11

For  $\bar{A}$  → possible combinations  
for which  $F$  can be 1

000  
001  
010  
011  
} place a '1' in  
the respective  
cells

Determine the product terms for the K-Map in fig & write the resulting minimum SOP expression.



$$f = \bar{A}\bar{B}\bar{C} + BC + AB$$

Determine the product terms for the K-Map in fig & write the resulting minimum SOP expression.



Minimum SOP Expression

$$f = \bar{B} + AC + \bar{A}\bar{C}$$

Use a K-Map to minimize the following SOP expression.  $F = A\bar{B}C + \bar{A}BC + \bar{A}\bar{B}C + \bar{A}\bar{B}\bar{C} + A\bar{B}\bar{C}$



$$f = \bar{B} + \bar{A}C$$

**Practice problems**  
① Obtain the simplified Boolean expression from the truth table in the SOP form.



$$f = A$$

② Obtain the standard SOP expression and simplified SOP expression from the K-Map.



$$(a) f = \bar{A} + \bar{B}C$$



$$(b) f = \bar{A}\bar{B} + A\bar{C} + \bar{B}\bar{C}$$

$f(A, B, C) = \Sigma m(0, 1, 3, 5, 7)$  minimize this by K map.

$$\text{Ans } f(A, B, C) = C + \bar{A}\bar{B}$$

③ Simplify the logic function F in the following cases:

$$a) F(A, B, C) = \Sigma m(1, 3, 4, 7)$$



$$f = A\bar{B}\bar{C} + \bar{B}C + \bar{A}C$$

## CSE1003 Digital Logic and Design

Module 2  
BOOLEAN ALGEBRA L7

Dr. S. Hemamalini  
Professor  
School of Electrical Engineering  
VIT Chennai

## Module 2

### BOOLEAN ALGEBRA      8 hrs

#### Boolean algebra

- Properties of Boolean algebra
- Boolean functions
- Canonical and Standard forms
- Logic gates - Universal gates
- Karnaugh map - Don't care conditions
- Tabulation Method

### Tabulation Method

- Step-by-step procedure for simplification by the tabular or Quine-McCluskey method.
  - Identify the **prime implicants**.
  - **Essential prime implicants** are determined by preparing a **prime implicants chart**.
  - The minterms that are not covered by the essential prime implicants, are taken into consideration by selecting some more prime implications to obtain an optimized Boolean expression.

Prime implicants are expressions with least number of literals that represents all the terms given in a truth table.

### Tabulation Method

- Also known as the *Quine-McCluskey method*.
- *It is a straightforward, systematic method for producing a minimal function that is less dependent on the designer's ability to recognize patterns than the K-map method.*
- *It is a viable scheme for handling a large number of variables as opposed to the K-map (limited to 5 or 6 variables).*
- *Can also be extended to functions with multiple outputs.*

### Determination of Prime Implicants

1. Each minterm of the function is expressed by its binary representation.
2. The minterms are arranged according to increasing index (index is defined as the number of 1s in a minterm). Each set of minterms possessing the same index are separated by lines.
3. Now each of the minterms is compared with the minterms of a higher index. For each pair of terms that can combine, the new terms are formed. If two minterms are differed by only one variable, that variable is replaced by a '-' (dash) to form the new term with one less number of literals. A line is drawn in when all the minterms of one set is compared with all the minterms of a higher index.
4. The same process is repeated for all the groups of minterms. A new list of terms is obtained after the first stage of elimination is completed.
5. At the next stage of elimination two terms from the new list with the '-' of the same position differing by only one variable are compared and again another new term is formed with a less number of literals.
6. The process is to be continued until no new match is possible.
7. All the terms that remain unchecked *i.e.*, where no match is found during the process, are considered to be the prime implicants.

## Prime Implicant Chart

1. After obtaining the prime implicants, a chart or table is prepared where rows are represented by the prime implicants and the columns are represented by the minterms of the function.
2. Crosses are placed in each row to show the composition of the minterms that makes the prime implicants.
3. A completed prime implicant table is to be inspected for the columns containing only a single cross. Prime implicants that cover the minterms with a single cross are called the essential prime implicants.

## Quine-McCluskey method

**Step 2.** Perform an exhaustive search between neighboring groups for adjacent minterms and combine them into a column of  $(n - 1)$ -variable implicants, checking off each minterm that is combined. The binary representation of each new implicant contains a dash in the position of the eliminated variable. Repeat for each column, combining  $(n - 1)$ -variable implicants into  $(n - 2)$ -variable implicants, and so on, until no further implicants can be combined. Any term not checked off represents a prime implicant of the function, since it is not covered by a larger implicant. The final result is a list of prime implicants of the switching function.

## Quine-McCluskey method

**Step 1.** List in a column all the minterms of the function to be minimized in their binary representation. Partition them into groups according to the number of 1 bits in their binary representations. This partitioning simplifies identification of logically adjacent minterms since, to be logically adjacent, two minterms must differ in exactly one literal, and therefore the binary representation of one minterm must have either one more or one fewer 1 bit than the other.

## Quine-McCluskey method

**Step 3.** Construct a prime implicant chart that lists minterms along the horizontal and prime implicants along the vertical, with an  $\times$  entry placed wherever a certain prime implicant (row) covers a given minterm (column).

**Step 4.** Select a minimum number of prime implicants that cover all the minterms of the switching function.

## Quine-McCluskey method

Minimize the following expression using Q-M method.  $f(A, B, C, D) = \sum m(2, 4, 6, 8, 9, 10, 12, 13, 15)$

| Minterms | $ABCD$ |
|----------|--------|
| 2        | 0010   |
| 4        | 0100   |
| 8        | 1000   |
| 6        | 0110   |
| 9        | 1001   |
| 10       | 1010   |
| 12       | 1100   |
| 13       | 1101   |
| 15       | 1111   |

Group 1 (a single 1)

Group 2 (two 1's)

Group 3 (three 1's)

Group 4 (four 1's)

|                     |   |   |   |   |   |    |    |    |    |
|---------------------|---|---|---|---|---|----|----|----|----|
|                     | 2 | 4 | 6 | 8 | 9 | 10 | 12 | 13 | 15 |
| * * PI <sub>1</sub> |   |   |   | x | ⊗ |    | x  | x  |    |
| PI <sub>2</sub>     | x |   | x |   |   |    |    |    |    |
| PI <sub>3</sub>     | x |   |   |   |   | x  |    |    |    |
| PI <sub>4</sub>     |   | x | x |   |   |    |    |    |    |
| PI <sub>5</sub>     |   | x |   |   |   | x  |    |    |    |
| PI <sub>6</sub>     |   |   | x |   | x |    |    |    |    |
| * * PI <sub>7</sub> |   |   |   |   |   |    | x  | ⊗  |    |

$$\begin{aligned}
 f(A, B, C, D) &= PI_1 + PI_3 + PI_4 + PI_7 \\
 &= 1-0- + -010 + 01-0 + 11-1 \\
 &= A\bar{C} + \bar{B}C\bar{D} + \bar{A}\bar{B}\bar{D} + ABD
 \end{aligned}$$

|                  |   |   |   |    |
|------------------|---|---|---|----|
|                  | √ | √ | √ | √  |
| 2                | 2 | 4 | 6 | 10 |
| PI <sub>2</sub>  | x |   | x |    |
| *PI <sub>3</sub> | x |   |   | x  |
| *PI <sub>4</sub> |   | x | x |    |
| PI <sub>5</sub>  |   | x |   |    |
| PI <sub>6</sub>  |   |   |   | x  |

| List 1  |        | List 2   |        | List 3   |                 |
|---------|--------|----------|--------|----------|-----------------|
| Minterm | $ABCD$ | Minterms | $ABCD$ | Minterms | $ABCD$          |
| 2       | 0010   | √        | 2, 6   | 0-10     | PI <sub>2</sub> |
| 4       | 0100   | √        | 2, 10  | -010     | PI <sub>3</sub> |
| 8       | 1000   | √        | 4, 6   | 01-0     | PI <sub>4</sub> |
| 6       | 0110   | √        | 4, 12  | -100     | PI <sub>5</sub> |
| 9       | 1001   | √        | 8, 9   | 100-     | √               |
| 10      | 1010   | √        | 8, 10  | 10-0     | PI <sub>6</sub> |
| 12      | 1100   | √        | 8, 12  | 1-00     | √               |
| 13      | 1101   | √        | 9, 13  | 1-01     | √               |
| 15      | 1111   | √        | 12, 13 | 110-     | √               |
|         |        |          | 13, 15 | 11-1     | PI <sub>7</sub> |

## Rules for PI chart reduction

**Rule 1.** A row that is *covered* by another row may be eliminated from the chart. When identical rows are present, all but one of the rows may be eliminated.

**Rule 2.** A column that *covers* another column may be eliminated. All but one column from a set of identical columns may be eliminated.

|                 |   |    |    |    |
|-----------------|---|----|----|----|
|                 | 5 | 10 | 11 | 13 |
| PI <sub>2</sub> | x |    |    | x  |
| PI <sub>3</sub> | x |    |    | x  |
| PI <sub>4</sub> |   | x  | x  |    |
| PI <sub>5</sub> |   |    | x  | x  |
| PI <sub>6</sub> |   | x  | x  |    |

|                   |   |    |
|-------------------|---|----|
|                   | √ | √  |
| 5                 | 5 | 10 |
| * PI <sub>2</sub> | x |    |
| *PI <sub>4</sub>  |   | x  |

Simplify the following function using Quine-McCluskey method.

$$Y(A, B, C, D) = \Sigma m(0, 2, 3, 5, 7, 8, 12, 13)$$

**STEP 1:**

- The minterms of the function are represented in binary form as shown in Table 1.
- The binary representation are grouped into a number of sections in terms of the number of 1's index as shown in Table 2.

| Minterms | Binary<br>ABCD | No. of 1's | Minterms<br>Group | Index | Binary<br>ABCD |
|----------|----------------|------------|-------------------|-------|----------------|
| $m_0$    | 0000           | 0          | 0                 | 0     | 0000 ✓         |
| $m_2$    | 0010           | 1          | 2                 |       | 0010 ✓         |
| $m_3$    | 0011           | 2          | 8                 | I     | 1000 ✓         |
| $m_5$    | 0101           | 2          | 3                 |       | 0011 ✓         |
| $m_7$    | 0111           | 3          | 5                 | II    | 0101 ✓         |
| $m_8$    | 1000           | 1          | 12                |       | 1100 ✓         |
| $m_{12}$ | 1100           | 2          | 7                 | III   | 0111 ✓         |
| $m_{13}$ | 1101           | 3          | 13                |       | 1101 ✓         |

**STEP 2:**

- Compare every term of the lowest group with each term in the adjacent group.
- If two minterms differ in only one variable, that variable should be removed and a dash (-) is placed at the position, thus a new term with one less literal is formed.
- If such a situation occurs, a check mark (✓) is placed next to both minterms.
- After all pairs of terms have been considered, a horizontal line is drawn under the last terms as depicted in Table.

| The combinations of two minterms |       |                |                |        |       |
|----------------------------------|-------|----------------|----------------|--------|-------|
| Minterms Group                   | Index | Binary<br>ABCD | Minterms Group | Binary |       |
|                                  |       |                |                | A      | B C D |
| 0                                | 0     | 0000 ✓         | 0, 2           | 0      | 0 - 0 |
| 2                                |       | 0010 ✓         | 0, 8           | -      | 0 0 0 |
| 8                                | I     | 1000 ✓         | 2, 3           | 0      | 0 1 - |
| 3                                |       | 0011 ✓         | 8, 12          | 1      | - 0 0 |
| 5                                | II    | 0101 ✓         | 3, 7           | 0      | - 1 1 |
| 12                               |       | 1100 ✓         | 5, 7           | 0      | 1 - 1 |
| 7                                | III   | 0111 ✓         | 5, 13          | -      | 1 0 1 |
| 13                               |       | 1101 ✓         | 12, 13         | 1      | 1 0 - |

**Step 3:**

- Now repeat step-2 with newly formed groups i.e. combine four minterms of adjacent groups if possibilities exist.
- In this case, dashes (-) exist in same position of two groups and only one position will be different.
- No four minterm group is possible here.

**STEP 4:**

- All terms which remain unchecked are the PIs.
- Remove repeated prime implicants as shown in Table.
- Now, construct the prime implicant chart as shown in table.

**Prime implicants chart**

| Prime Implicants | Minterms |   |   |   |   |   |    |    |
|------------------|----------|---|---|---|---|---|----|----|
|                  | 0        | 2 | 3 | 5 | 7 | 8 | 12 | 13 |
| 0, 2*            | ✗        | ✗ |   |   |   |   |    |    |
| 0, 8             | ✗        |   |   |   |   |   | ✗  |    |
| 2, 3             |          | ✗ | ✗ |   |   |   |    |    |
| 8, 12*           |          |   |   |   |   |   | ✗  | ✗  |
| 3, 7*            |          |   |   | ✗ | ✗ |   |    |    |
| 5, 7             |          |   |   |   | ✗ | ✗ |    |    |
| 5, 13*           |          |   |   |   |   | ✗ |    |    |
| 12, 13           |          |   |   |   |   |   | ✗  | ✗  |

**Step 5:**

- Here the function does not have any essential prime implication.
- So choose the prime implicants such that all minterms are covered.

| Prime Implicants | Binary Representation | Product Term              |
|------------------|-----------------------|---------------------------|
| 0, 2             | 0 0 - 0               | $\bar{A} \bar{B} \bar{D}$ |
| 8, 12            | 1 - 0 1               | $A \bar{C} \bar{D}$       |
| 3, 7             | 0 - 1 1               | $\bar{A} C D$             |
| 5, 13            | - 1 0 1               | $B \bar{C} D$             |

Minimized SOP expression

$$f(A, B, C, D) = \bar{A} \bar{B} \bar{D} + A \bar{C} \bar{D} + \bar{A} C D + B \bar{C} D$$

Simplify the following function using Quine-McCluskey method.

$$f(A, B, C, D) = \Sigma m(7, 9, 12, 13, 14, 15) + d(4, 11)$$

| Minterms | Binary<br>ABCD | No. of 1's | Minterm Group | Index | Binary<br>ABCD |
|----------|----------------|------------|---------------|-------|----------------|
| $m_7$    | 0111           | 3          | $m_4$         | I     | 0100 ✓         |
| $m_9$    | 1001           | 2          | $m_9$         | II    | 1001 ✓         |
| $m_{12}$ | 1100           | 2          | $m_{12}$      |       | 1100 ✓         |
| $m_{13}$ | 1101           | 3          | $m_7$         |       | 0111 ✓         |
| $m_{14}$ | 1110           | 3          | $m_{11}$      | III   | 1011 ✓         |
| $m_{15}$ | 1111           | 4          | $m_{13}$      |       | 1101 ✓         |
| $m_4$    | 0100           | 1          | $m_{14}$      |       | 1110 ✓         |
| $m_{11}$ | 1011           | 3          | $m_{15}$      | IV    | 1111 ✓         |

## CSE1003 Digital Logic and Design

### Module 3 Combinational Circuits I L1

Dr. S. Hemamalini

Professor

School of Electrical Engineering

VIT Chennai

| Minterm Group | Index | Binary<br>ABCD | Combination of two minterms |        |       |   | Combination of four minterms |                |        |   |   |   |
|---------------|-------|----------------|-----------------------------|--------|-------|---|------------------------------|----------------|--------|---|---|---|
|               |       |                | Binary                      |        |       |   | Binary                       |                |        |   |   |   |
|               |       |                | A                           | B      | C     | D |                              | A              | B      | C |   |   |
| $m_4$         | I     | 0100 ✓         |                             |        |       |   |                              |                |        |   |   |   |
| $m_9$         | II    | 1001 ✓         | 4, 12                       | -      | 1     | 0 | 0                            | 9, 11, 13, 15  | 1      | - | 1 |   |
| $m_{12}$      |       | 1100 ✓         |                             | 9, 11  | 1     | 0 | -                            | 10, 13, 11, 15 | 1      | - | 1 |   |
| $m_7$         |       | 0111 ✓         |                             | 9, 13  | 1     | - | 0                            | 12, 13, 14, 15 | 1      | - | - |   |
| $m_{11}$      | III   | 1011 ✓         |                             | 12, 13 | 1     | 1 | 0                            | 12, 14, 13, 15 | 1      | 1 | - |   |
| $m_{13}$      |       | 1101 ✓         |                             | 12, 14 | 1     | 1 | -                            |                | 1      | 1 | - |   |
| $m_{14}$      |       | 1110 ✓         |                             | 7, 15  | -     | 1 | 1                            | 11, 15         | 1      | - | 1 |   |
| $m_{15}$      | IV    | 1111 ✓         |                             |        | 7, 15 | 1 | -                            | 1              | 13, 15 | 1 | 1 | - |
|               |       |                |                             |        |       | 1 | -                            | 1              | 14, 15 | 1 | 1 | 1 |
|               |       |                |                             |        |       |   |                              |                |        |   |   |   |

PI

Prime implicant chart

| Prime Implicants | Binary Representation | Variable Representation |
|------------------|-----------------------|-------------------------|
| 4, 12            | - 1 0 0               | $B\bar{C}\bar{D}$       |
| 7, 15            | - 1 1 1               | $BCD$                   |
| 9, 11, 13, 15    | 1 - - 1               | $AD$                    |
| 12, 13, 14, 15   | 1 1 - -               | $AB$                    |

## Contents

4 hrs

- Adder
- Subtractor
- Code converter
- Analyzing a combinational circuit

# Digital Circuits

## Combinational Logic Circuits

- Output at any instant of time depends only on the inputs present at that instant of time.
- The logic gate is the most basic building block of combinational logic.
- Combinational logic circuits do not have memory elements (storage device).
- It can be designed using gates or available ICs.
- Adder, subtractor, ALU comparators, parity generator and checker, multiplexer, demultiplexer, encoder, and code converters are the examples of combinational logic circuits.

## Sequential Logic Circuits

- The output depends upon not only the present but also the past state of inputs.
- Sequential circuits comprise both logic gates and memory elements such as flip-flops.



# Block diagram of a combinational circuit



# ARITHMETIC CIRCUITS

## Arithmetic/Logic Unit

- All arithmetic operations take place in the arithmetic/logic unit (ALU) of a computer.
- The arithmetic/logic unit contains at least two flip-flop registers: the B register and the accumulator register.
- It also contains combinational logic, which performs the arithmetic and logic operations on the binary numbers that are stored in the B register and the accumulator.



# DESIGN PROCEDURE

Any combinational circuit can be designed by the following steps of design procedure.

1. The problem is stated.
2. Identify the input variables and output functions.
3. The input and output variables are assigned letter symbols.
4. The truth table is prepared that completely defines the relationship between the input variables and output functions.
5. The simplified Boolean expression is obtained by any method of minimization—algebraic method, Karnaugh map method, or tabulation method.
6. A logic diagram is realized from the simplified expression using logic gates.

## Design Constraints

- (1) minimum number of gates
- (2) Minimum number of outputs
- (3) minimum propagation time of the signal through a circuit
- (4) minimum number of interconnections
- (5) limitations of the driving capabilities of each logic gate

## ADDERS

- The most basic arithmetic operation is the addition of two binary digits.

$$0 + 0 = 0$$

$$0 + 1 = 1$$

$$1 + 0 = 0$$

$$1 + 1 = 10$$

**Carry**      **Sum**

- A combinational circuit that performs the addition of two 1-bit numbers is called as **half-adder**.
- The logic circuit that adds three 1-bit numbers is called as **full-adder**.

## Half-Adder

Truth table for half-adder

| Inputs |   | Outputs |           |
|--------|---|---------|-----------|
| A      | B | Sum (S) | Carry (C) |
| 0      | 0 | 0       | 0         |
| 0      | 1 | 1       | 0         |
| 1      | 0 | 1       | 0         |
| 1      | 1 | 0       | 1         |

Block diagram of a half-adder



- The logic circuit that performs the addition of two 1-bit numbers is called as half-adder.
- It is the basic building block for addition of two single bit numbers.
- This circuit has two outputs namely Carry (C) and Sum (S).

## Half-Adder

- K-map Simplification for Carry and Sum**



K-map for sum output



K-map for carry output

$$S = \overline{AB} + A\overline{B} = (A \oplus B)$$

$$C = A \cdot B$$



## Logic diagram of half-adder using only 2-input NOR gates

$$\begin{aligned} \text{Sum, } S &= A\bar{B} + \bar{A}B = A\bar{B} + A\bar{A} + \bar{A}B + B\bar{B} \\ &= A(\bar{A} + \bar{B}) + B(\bar{A} + \bar{B}) \\ &= (A + B)(\bar{A} + \bar{B}) \\ &= \overline{(A + B)(\bar{A} + \bar{B})} \\ &= \overline{A + B + \bar{A} + \bar{B}} \end{aligned}$$

$$\text{Carry, } C = AB = \overline{\bar{A}\bar{B}} = \overline{\bar{A} + \bar{B}}$$



## Full-Adder

- A half-adder has two 1-bit inputs and there is no provision to add a carry which could have been generated from lower bit order additions. This limitation of half-adder is overcome in full-adder.
- A full adder circuit is an arithmetic circuit block that can be used to add three bits to produce a sum and a carry output.

For the half-adder circuit of Figure (a), the inputs applied at A and B are as shown in Figure (b). Plot the corresponding SUM and CARRY outputs for the half-adder.



| Inputs |   |       | Outputs |                 |
|--------|---|-------|---------|-----------------|
| A      | B | $C_m$ | Sum (S) | Carry $C_{out}$ |
| 0      | 0 | 0     | 0       | 0               |
| 0      | 0 | 1     | 1       | 0               |
| 0      | 1 | 0     | 1       | 0               |
| 0      | 1 | 1     | 0       | 1               |
| 1      | 0 | 0     | 1       | 0               |
| 1      | 0 | 1     | 0       | 1               |
| 1      | 1 | 0     | 0       | 1               |
| 1      | 1 | 1     | 1       | 1               |

K-map for sum S      K-map for  $C_{out}$



$$\begin{aligned} \text{Sum, } S &= \overline{A}\overline{B}C_m + \overline{A}B\overline{C}_m + ABC_m + A\overline{B}\overline{C}_m \\ &= C_m(\overline{A}\overline{B} + AB) + \overline{C}_m(\overline{A}B + A\overline{B}) \\ &= C_m(A \odot B) + \overline{C}_m(A \oplus B) \\ &= C_m(\overline{A} \oplus \overline{B}) + \overline{C}_m(A \oplus B) \\ S &= C_m \oplus A \oplus B \end{aligned}$$

$$\text{Carry, } C_{out} = AB + AC_m + BC_m$$

## Full-Adder

The full-adder circuit can be formed with two half-adders and one OR gate.



Logic circuit



Symbol

## Full-Adder using NAND Gates



Logic diagram of a full-adder using only 2-input NAND gates

## Full-Adder



## SUBTRACTORS

- The logic circuit of subtraction of two 1-bit numbers is called as **half-subtractor**.
- The logic circuit, which performs the subtraction of two 1-bit numbers, taking into account the borrow of the previous stage, is called as **full-subtractor**.

$$0 - 0 = 0$$

$$1 - 0 = 1$$

$$1 - 1 = 0$$

$$0 - 1 = 1 \text{ (with borrow 1)}$$

## Half-Subtractor

| Truth Table of Half-subtractor |     |         |           |
|--------------------------------|-----|---------|-----------|
| Inputs                         |     | Outputs |           |
| $A$                            | $B$ | $D$     | $B_{out}$ |
| 0                              | 0   | 0       | 0         |
| 0                              | 1   | 1       | 1         |
| 1                              | 0   | 1       | 0         |
| 1                              | 1   | 0       | 0         |



### Block diagram of a half-subtractor



$$D = \overline{A,B} + A,\overline{B}$$

$$B_o = \overline{A} \cdot B$$

## Full-Subtractor

- A full subtractor performs subtraction operation on two bits, a minuend and a subtrahend.
  - It also takes into consideration whether a '1' has already been borrowed by the previous adjacent lower minuend bit or not.
  - Therefore, there are three input bits, namely the two bits to be subtracted and a borrow bit designated as  $Bin$ .
  - There are two outputs, namely the difference output  $D$  and the borrow output  $Bout$ .
  - The BORROW output bit tells whether the minuend bit needs to borrow a '1' from the next possible higher minuend bit.



# Half-Subtractor using NOR Gates



### Logic diagram of a half-subtractor using only 2-input NOR gates

$$B \equiv \overline{A}B \equiv \overline{A}(A+B) \equiv \overline{\overline{A}(A+B)} \equiv \overline{A+(\overline{A}+B)}$$

| Truth table of Full-Subtractor |   |          |         |           |  |
|--------------------------------|---|----------|---------|-----------|--|
| Inputs                         |   |          | Outputs |           |  |
| A                              | B | $B_{in}$ | D       | $B_{out}$ |  |
| 0                              | 0 | 0        | 0       | 0         |  |
| 0                              | 0 | 1        | 1       | 1         |  |
| 0                              | 1 | 0        | 1       | 1         |  |
| 0                              | 1 | 1        | 0       | 1         |  |
| 1                              | 0 | 0        | 1       | 0         |  |
| 1                              | 0 | 1        | 0       | 0         |  |
| 1                              | 1 | 0        | 0       | 0         |  |
| 1                              | 1 | 1        | 1       | 1         |  |



### Karnaugh maps for difference and borrow outputs

$$D \equiv \overline{A}.\overline{B}.B_{\perp} + \overline{A}.B.\overline{B}_{\perp} + A.\overline{B}.\overline{B}_{\perp} + A.B.B_{\perp}$$

$$B_2 \equiv \overline{A}_i \overline{B}_j B_{ij} + \overline{A}_i B_j \overline{B}_{ij} + \overline{A}_i B_i B_{ij} + A_i B_j B_{ij}$$

$$B_{\perp} \equiv \overline{A}_+ B + \overline{A}_- B_{\perp} + B_+ B_{\perp}$$

## Full-Subtractor

A full subtractor using two half-subtractors



## Full Subtractor Using NAND Gates



Difference,

$$\begin{aligned} D &= A \oplus B \oplus B_{in} = \overline{(A \oplus B)} \oplus B_{in} \\ &= \overline{(A \oplus B)} \overline{(A \oplus B)} B_{in} \cdot B_{in} \overline{(A \oplus B)} B_{in} \end{aligned}$$

where,

$$A \oplus B = A \cdot \overline{AB} + \overline{B} \cdot AB$$

Borrow,

$$\begin{aligned} B_{out} &= \overline{AB} + B_{in} \overline{(A \oplus B)} = \overline{AB} + B_{in} \overline{(A \oplus B)} \\ &= \overline{\overline{AB}} \cdot \overline{\overline{B_{in} (A \oplus B)}} \\ &= \overline{B} (\overline{A} + \overline{B}) \cdot B_{in} (\overline{B_{in}} + \overline{(A \oplus B)}) \\ B_{out} &= [B \cdot \overline{AB}] \cdot [\overline{B_{in}} \overline{B_{in} \cdot (A \oplus B)}] \end{aligned}$$

*CSE1003 Digital Logic and Design  
Module 3  
Combinational Circuits I  
L3*

DR. S. HEMAMALINI

PROFESSOR

SCHOOL OF ELECTRICAL ENGINEERING  
VIT CHENNAI

## Contents

4 hrs

Adder

Subtractor

Code converter

Analyzing a combinational circuit

## Codes

- Codes are used extensively with computers to define alphanumeric characters and other information.

The commonly used binary codes are classified as:

- Weighted and non-weighted codes
- Numeric and alphanumeric codes
- Error detecting and correcting codes
- Self-complementary codes
- Unit distance codes (Cyclic codes)
- Sequential Codes
- Reflective Codes

## Binary-Coded-Decimal Code (8421 Code)

- If each digit of a decimal number is represented by its binary equivalent, the result is a code called binary-coded decimal.
- The 10 decimal digits 0 through 9 can be represented by their corresponding 4-bit binary numbers.
- It is a weighted code, with 8, 4, 2 and 1 representing the weights of different bits in the four-bit groups, starting from MSB and going towards LSB.
- BCD code is also known as 8421 code or natural binary code.
- It is also sequential. Therefore, it is useful for mathematical operations.

$8 \rightarrow 1000$   
 $12 \rightarrow 0001\ 0010$

## Binary-Coded-Decimal Code (8421 Code)

- The four-bit binary numbers from 0000 through 1001 are used.
- The BCD code does not use the numbers 1010, 1011, 1100, 1101, 1110, and 1111.
- If any of the "forbidden" four-bit numbers ever occurs in a machine using the BCD code, it is usually an indication that an error has occurred.

| Decimal Numbers | BCD Bit encoding |
|-----------------|------------------|
| 0               | 0000             |
| 1               | 0001             |
| 2               | 0010             |
| 3               | 0011             |
| 4               | 0100             |
| 5               | 0101             |
| 6               | 0110             |
| 7               | 0111             |
| 8               | 1000             |
| 9               | 1001             |
| 10              | 1010             |
| 11              | 1011             |
| 12              | 1100             |
| 13              | 1101             |
| 14              | 1110             |
| 15              | 1111             |

Valid  
BCD code

Invalid  
BCD Code

## Binary-Coded-Decimal Code (8421 Code)

|        |        |        |                                            |        |        |        |                                            |
|--------|--------|--------|--------------------------------------------|--------|--------|--------|--------------------------------------------|
| 8<br>↓ | 7<br>↓ | 4<br>↓ | (decimal)<br>1000    0111    0100    (BCD) | 9<br>↓ | 4<br>↓ | 3<br>↓ | (decimal)<br>1001    0100    0011    (BCD) |
|--------|--------|--------|--------------------------------------------|--------|--------|--------|--------------------------------------------|

$874_{10} \rightarrow 1000\ 0111\ 0100$  BCD

23.15 (decimal)

0010 0011.0001 0101 (BCD)

## Binary-Coded-Decimal Code (8421 Code)

### Conversion of BCD code to decimal

- Start at the rightmost bit and break the code into groups of 4 bits.
- Write the decimal digit represented by each 4-bit group.

Convert the following BCD codes to decimal.

10000110  
↓  
8  
6  
10

001101010001  
↓  
351<sub>10</sub>

1001010001110000  
↓  
9470<sub>10</sub>

## Binary-Coded-Decimal Code (8421 Code)

Convert 011010000111001 (BCD) to its decimal equivalent.

0110 1000 0011 1001  
6 8 3 9

Convert the BCD number 01111000001 to its decimal equivalent.

0111 1100 0001  
7 ↓ 1

The forbidden code group indicates an error in the BCD number.

## BCD-to-Binary Conversion

- First, write the decimal equivalent of given BCD number and then convert it into binary equivalent.

Convert the following BCD code into its equivalent binary.

[00101001.01110101]<sub>BCD</sub>

Given BCD number : 0010 1001 . 0111 0101

Decimal equivalent : 2 9 . 7 5

$$(29.75)_{10} = (11101.11)_2$$

### Conversion of integer part:

| Quotient | Remainder | • LSB |
|----------|-----------|-------|
| 29 ÷ 2   | 14        | 1     |
| 14 ÷ 2   | 7         | 0     |
| 7 ÷ 2    | 3         | 1     |
| 3 ÷ 2    | 1         | 1     |
| 1 ÷ 2    | 0         | 1     |

### Conversion of fractional part:

Multiplication      Integer part

$$0.75 \times 2 = 1.5$$

$$0.5 \times 2 = 1.0$$

• MSB

• LSB

## Drawbacks of BCD code

- BCD code is less efficient than pure binary-requires more bits.
- An N digit decimal number is represented by 4 × N bits in BCD code.
- The BCD code of 137 is 12 bits and the binary code of 137 is 8 bits; it shows that the BCD code is not efficient as compared to binary.
- The BCD code requires more space and time to transmit the information.
- Arithmetic operations are more complex than they are in pure binary form.

Comparison of BCD and binary  
 $137_{10} = 10001001_2$  (binary)  
 $137_{10} = 0001\ 0011\ 0111$  (BCD)  
12 bits

## Excess-3 code

Excess-3 code is non-weighted and sequential code and it is useful for arithmetic operations.

The excess-3 code for a given decimal number is determined by adding '3' to each decimal digit in the given number and then replacing each digit of the newly found decimal number by its four-bit binary equivalent.

The XS-3 code has six invalid states 0000, 0001, 0010, 1101, 1110 and 1111.

| Decimal    | Excess-3 |
|------------|----------|
| 0 + 3 = 3  | 0011     |
| 1 + 3 = 4  | 0100     |
| 2 + 3 = 5  | 0101     |
| 3          | 0110     |
| 4          | 0111     |
| 5          | 1000     |
| 6          | 1001     |
| 7          | 1010     |
| 8          | 1011     |
| 9 + 3 = 12 | 1100     |

Decimal 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15  
0 - 16  
3 to 12 - used

## Excess-3 code

|         |         |                         |
|---------|---------|-------------------------|
| 0 1 0 1 | 0 1 1 0 | • BCD code of 56        |
| 0 0 1 1 | 0 0 1 1 | • Add 3 to each digit   |
| 1 1 1   | 1 1     | • Carry                 |
| 1 0 0 0 | 1 0 0 1 | • Excess-3 code of (56) |

- ❑ In excess-3 code, the N digit decimal is represented by  $4 \times N$  bits.
- ❑ For example, excess-3 code of 12 is 01000101 and there are 8 bits.
- ❑ The binary code of 12 is 1100 and there are 4 bits.
- ❑ This shows that the excess-3 code is not efficient as compared to binary.
- ❑ It requires more space and time to transmit the information.

## Binary codes for decimal digits

| Decimal digit | (BCD) 8421 | 84-2-1 | 2421 | Excess-3 |
|---------------|------------|--------|------|----------|
| 0             | 0000       | 0000   | 0000 | 0011     |
| 1             | 0001       | 0111   | 0001 | 0100     |
| 2             | 0010       | 0110   | 0010 | 0101     |
| 3             | 0011       | 0101   | 0011 | 0110     |
| 4             | 0100       | 0100   | 0100 | 0111     |
| 5             | 0101       | 1011   | 1011 | 1000     |
| 6             | 0110       | 1010   | 1100 | 1001     |
| 7             | 0111       | 1001   | 1101 | 1010     |
| 8             | 1000       | 1000   | 1110 | 1011     |
| 9             | 1001       | 1111   | 1111 | 1100     |

## Gray Codes

- ❖ Gray code belongs to a class of code known as minimum change code, in which a number changes by only one bit as it proceeds from one number to the next.
- ❖ Hence this code is not useful for arithmetic operations.
- ❖ This code finds extensive use for shaft encoders, in some types of analog-to-digital converters, etc.
- ❖ Gray code is reflected code.
- ❖ The Gray code is not a weighted code.

| Decimal numbers | Binary code | Gray code |
|-----------------|-------------|-----------|
| 0               | 0000        | 0000      |
| 1               | 0001        | 0001      |
| 2               | 0010        | 0011      |
| 3               | 0011        | 0010      |
| 4               | 0100        | 0110      |
| 5               | 0101        | 0111      |
| 6               | 0110        | 0101      |
| 7               | 0111        | 0100      |
| 8               | 1000        | 1100      |
| 9               | 1001        | 1101      |
| 10              | 1010        | 1111      |
| 11              | 1011        | 1110      |
| 12              | 1100        | 1010      |
| 13              | 1101        | 1011      |
| 14              | 1110        | 1001      |
| 15              | 1111        | 1000      |

## Conversion of a Binary Number into Gray Code

- (i) the MSB of the Gray code is the same as the MSB of the binary number;
- (ii) the second bit next to the MSB of the Gray code equals the Ex-OR of the MSB and second bit of the binary number; it will be 0 if there are same binary bits or it will be 1 for different binary bits;
- (iii) the third bit for Gray code equals the exclusive-OR of the second and third bits of the binary number, and similarly all the next lower order bits follow the same mechanism.

|        |                           |          |   |          |   |          |   |          |
|--------|---------------------------|----------|---|----------|---|----------|---|----------|
|        | $(74)_{10} = (1001010)_2$ |          |   |          |   |          |   |          |
| Binary | 1                         | $\oplus$ | 0 | $\oplus$ | 0 | $\oplus$ | 1 | $\oplus$ |
| Gray   | 1                         | ↓        | 1 | ↓        | 0 | ↓        | 1 | ↓        |

Gray code of 74 = 1101111

## Gray-to-Binary Code Conversion

1. The most significant bit (left most bit) of the equivalent binary code is the same as the MSB of the given Gray code.
2. Add the MSB of the binary to the next significant bit of the Gray code, note the sum and ignore the carry.
3. Add the 2nd bit of the binary to the 3rd bit of the Gray; the 3rd bit of the binary to the 4th bit of the Gray code, and so on, each time note the sum and ignore the carry.
4. Continue above step till all Gray bits are used. This sequence of bits is the binary equivalent of the Gray code number.

For example the conversion of Gray code 11011 is shown as below.

|        |   |          |   |          |   |          |   |          |   |
|--------|---|----------|---|----------|---|----------|---|----------|---|
| Gray   | 1 | $\oplus$ | 1 | $\oplus$ | 0 | $\oplus$ | 1 | $\oplus$ | 1 |
| Binary | 1 | ↓        | 0 | ↓        | 0 | ↓        | 1 | ↓        | 0 |

## Alphanumeric Codes

- A computer must be capable of handling nonnumeric information like numbers, letters, and special characters. These codes are classified as alphanumeric or character codes.
- An alphanumeric code is a binary code of a group of elements consisting of ten decimal digits, the 26 letters of the alphabet (both in uppercase and lowercase), and a certain number of special symbols such as #, /, &, %, etc.

## ASCII code

- American Standard Codes for Information Interchanging (ASCII) is the most widely used alphanumeric code.
- This is basically a 7-bit code and so, it has  $2^7 = 128$  possible code groups.
- The ASCII code can be used to encode both the lowercase and uppercase characters of the alphabet (52 symbols) and some special symbols as well, in addition to the 10 decimal digits.
- This code is used to exchange the information between input/output device and computers, and stored into the memory.

**American Standard Code for Information Interchange (ASCII)****ASCII code**

*b<sub>7</sub> b<sub>6</sub> b<sub>5</sub> b<sub>4</sub> b<sub>3</sub> b<sub>2</sub> b<sub>1</sub>*

|   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|
| A | 1 | 0 | 0 | 0 | 0 | 0 | 1 |
| b | 1 | 1 | 0 | 0 | 1 | 0 | 0 |

| <i>b<sub>4</sub> b<sub>3</sub> b<sub>2</sub> b<sub>1</sub></i> | 000 | 001 | 010 | 011 | 100 | 101 | 110 | 111 |
|----------------------------------------------------------------|-----|-----|-----|-----|-----|-----|-----|-----|
| 0000 NUL DLE SP 0 @ P ` p                                      |     |     |     |     |     |     |     |     |
| 0001 SOH DC1 ! 1 A Q a q                                       |     |     |     |     |     |     |     |     |
| 0010 STX DC2 " 2 B R b r                                       |     |     |     |     |     |     |     |     |
| 0011 ETX DC3 # 3 C S c s                                       |     |     |     |     |     |     |     |     |
| 0100 EOT DC4 \$ 4 D T d t                                      |     |     |     |     |     |     |     |     |
| 0101 ENQ NAK % 5 E U e u                                       |     |     |     |     |     |     |     |     |
| 0110 ACK SYN & 6 F V f v                                       |     |     |     |     |     |     |     |     |
| 0111 BEL ETB , 7 G W g w                                       |     |     |     |     |     |     |     |     |
| 1000 BS CAN ( 8 H X h x                                        |     |     |     |     |     |     |     |     |
| 1001 HT EM ) 9 I Y i y                                         |     |     |     |     |     |     |     |     |
| 1010 LF SUB * : J Z j z                                        |     |     |     |     |     |     |     |     |
| 1011 VT ESC + ; K [ k {                                        |     |     |     |     |     |     |     |     |
| 1100 FF FS , < L \ l }                                         |     |     |     |     |     |     |     |     |
| 1101 CR GS - = M ] m }                                         |     |     |     |     |     |     |     |     |
| 1110 SO RS . > N ^ n ~                                         |     |     |     |     |     |     |     |     |
| 1111 SI US / ? O - o DEL                                       |     |     |     |     |     |     |     |     |

**CODE CONVERTERS**

- A code converter is a combinational logic circuit which accepts the input information in one binary code, converts it and produces an output into another binary code.

**BCD-to-Excess-3 Code converter**

Excess-3 code is a modified BCD code. It is obtained by adding 3 to each BCD code.

Note that the input combinations 1010, 1011, 1100, 1101, 1110, and 1111 are invalid in BCD. So they are treated as don't cares.

10 - 15

| Decimal Equivalent | BCD code |   |   |   | Excess-3 code |   |   |   |
|--------------------|----------|---|---|---|---------------|---|---|---|
|                    | A        | B | C | D | W             | X | Y | Z |
| 0                  | 0        | 0 | 0 | 0 | 0             | 0 | 1 | 1 |
| 1                  | 0        | 0 | 0 | 1 | 0             | 1 | 0 | 0 |
| 2                  | 0        | 0 | 1 | 0 | 0             | 1 | 0 | 1 |
| 3                  | 0        | 0 | 1 | 1 | 0             | 1 | 1 | 0 |
| 4                  | 0        | 1 | 0 | 0 | 0             | 1 | 1 | 1 |
| 5                  | 0        | 1 | 0 | 1 | 1             | 0 | 0 | 0 |
| 6                  | 0        | 1 | 1 | 0 | 1             | 0 | 0 | 1 |
| 7                  | 0        | 1 | 1 | 1 | 1             | 1 | 0 | 0 |
| 8                  | 1        | 0 | 0 | 0 | 1             | 0 | 1 | 1 |
| 9                  | 1        | 0 | 0 | 1 | 1             | 1 | 0 | 0 |

*W, X, Y, Z  
Input variables  
A, B, C, D  
Output variables*

**K-Maps for excess-3 codes**

$$W = A + BD + BC$$

$$Y = C'D + CD$$



$$X = BC'D + B'D + BC$$

$$Z = D'$$



### BCD-to-Excess-3 Code converter



### Excess-3-to-BCD Code Converter

| Decimal Equivalent | Excess-3 code |   |   |   | BCD code |   |   |   |
|--------------------|---------------|---|---|---|----------|---|---|---|
|                    | W             | X | Y | Z | A        | B | C | D |
| 0                  | 0             | 0 | 1 | 1 | 0        | 0 | 0 | 0 |
| 1                  | 0             | 1 | 0 | 0 | 0        | 0 | 0 | 1 |
| 2                  | 0             | 1 | 0 | 1 | 0        | 0 | 1 | 0 |
| 3                  | 0             | 1 | 1 | 0 | 0        | 0 | 1 | 1 |
| 4                  | 0             | 1 | 1 | 1 | 0        | 1 | 0 | 0 |
| 5                  | 1             | 0 | 0 | 0 | 0        | 1 | 0 | 1 |
| 6                  | 1             | 0 | 0 | 1 | 0        | 1 | 1 | 0 |
| 7                  | 1             | 0 | 1 | 0 | 0        | 1 | 1 | 1 |
| 8                  | 1             | 0 | 1 | 1 | 1        | 0 | 0 | 0 |
| 9                  | 1             | 1 | 0 | 0 | 1        | 0 | 0 | 1 |

### K-Maps for Excess-3-to-BCD Code Converter



Logic diagram of Excess-3 to-BCD code converter



## Logic diagram of an Excess-3-to-BCD converter



*CSE1003 Digital Logic and Design  
Module 4  
Combinational Circuits II  
L1*

DR. S. HEMAMALINI

PROFESSOR

SCHOOL OF ELECTRICAL ENGINEERING

VIT CHENNAI

## Contents

6 hrs

Binary Parallel Adder - Look ahead carry

Magnitude Comparator

Decoders

Encoders

Multiplexers

Demultiplexers

CO4: Analyze the operation of medium complexity standard combinational circuits like the encoder, decoder multiplexer, demultiplexer.

## Applications – Magnitude Comparators

❖ Magnitude comparators are useful in control applications where a binary number representing the physical variable being controlled (e.g., position, speed, or temperature) is compared with a reference value. The comparator outputs are used to actuate circuitry to drive the physical variable toward the reference value.

❖ Comparators are used in central processing units (CPUs) and microcontrollers (MCUs).

❖ Comparators are also used as process controllers and for Servo motor control.

❖ Used in password verification and biometric applications.

## Magnitude Comparator

- The comparator is a 2n-input, 3-output combinational logic circuit.
- It compares the magnitude of two n-bit numbers and provides the relative result as the output.



## 1-bit Magnitude Comparator

The one-bit comparator is a combinational logic circuit with two inputs A and B and three outputs namely A < B, A = B and A > B.

It compares the two single bit numbers A and B and produces an output that indicates the result of the comparison.

Let the 1-bit numbers be  $A = A_0$  and  $B = B_0$ .

### Design of 1-bit Magnitude Comparator

| $A_0$ | $B_0$ | $A < B$ | $A = B$ | $A > B$ |
|-------|-------|---------|---------|---------|
| 0     | 0     | 0       | 1       | 0       |
| 0     | 1     | 1       | 0       | 0       |
| 1     | 0     | 0       | 0       | 1       |
| 1     | 1     | 0       | 1       | 0       |

K-map for  $A < B$   
K-map for  $A = B$   
K-map for  $A > B$

Truth table of a one-bit comparator

| Inputs |     |            |            |            |
|--------|-----|------------|------------|------------|
| $A$    | $B$ | $X(A < B)$ | $Y(A = B)$ | $Z(A > B)$ |
| 0      | 0   | 0          | 1          | 0          |
| 0      | 1   | 1          | 0          | 0          |
| 1      | 0   | 0          | 0          | 1          |
| 1      | 1   | 0          | 1          | 0          |

Logic diagram of 1-bit comparator



For  $(A < B)$ ,  $X = \overline{A_0}B_0$   
For  $(A = B)$ ,  $Y = \overline{A_0}\overline{B_0} + A_0B_0 = \overline{A_0} \oplus \overline{B_0}$   
For  $(A > B)$ ,  $Z = A_0\overline{B_0}$

## Design of 2-bit Magnitude Comparator

A comparator used to compare two binary numbers each of two bits is called a 2-bit magnitude comparator.

It consists of four inputs and three outputs to generate less than, equal to and greater than between two binary numbers.

Let the two 2-bit binary numbers be  $A = A_1A_0$  and  $B = B_1B_0$ .

Here each subscript represents one of the digits in the numbers.

The binary numbers A and B will be equal if all the pairs of significant digits of both numbers are equal, i.e.,  $A_1 = B_1$  and  $A_0 = B_0$ .

Truth Table of 2-bit Magnitude Comparator

| INPUT |       |       |       | OUTPUT  |         |         |
|-------|-------|-------|-------|---------|---------|---------|
| $A_1$ | $A_0$ | $B_1$ | $B_0$ | $A < B$ | $A = B$ | $A > B$ |
| 0     | 0     | 0     | 0     | 0       | 1       | 0       |
| 0     | 0     | 0     | 1     | 1       | 0       | 0       |
| 0     | 0     | 1     | 0     | 1       | 0       | 0       |
| 0     | 0     | 1     | 1     | 1       | 0       | 0       |
| 0     | 1     | 0     | 0     | 0       | 0       | 1       |
| 0     | 1     | 0     | 1     | 0       | 1       | 0       |
| 0     | 1     | 1     | 0     | 1       | 0       | 0       |
| 0     | 1     | 1     | 1     | 1       | 0       | 0       |
| 1     | 0     | 0     | 0     | 0       | 0       | 1       |
| 1     | 0     | 0     | 1     | 0       | 0       | 1       |
| 1     | 0     | 1     | 0     | 0       | 1       | 0       |
| 1     | 0     | 1     | 1     | 1       | 0       | 0       |
| 1     | 1     | 0     | 0     | 0       | 0       | 1       |
| 1     | 1     | 0     | 1     | 0       | 0       | 1       |
| 1     | 1     | 1     | 0     | 0       | 0       | 1       |
| 1     | 1     | 1     | 1     | 0       | 1       | 0       |

Procedure to compare 2 2bit binary numbers:

- First compare the two most significant bits ( $A_1$  and  $B_1$ ).  
If  $A_1 > B_1$ , then  $A > B$ ;  
if  $A_1 < B_1$ , then  $A < B$ .  
If  $A_1 = B_1$ , then the next pair of bits ( $A_0$  and  $B_0$ ) must be compared.
- If  $A_1 = B_1$  and  $A_0 > B_0$ , then  $A > B$ ;  
if  $A_1 = B_1$  and  $A_0 < B_0$ , then  $A < B$ .  
Again, if  $A_1 = B_1$  and  $A_0 = B_0$ , then  $A = B$ .

## Design of 2-bit Magnitude Comparator

Truth Table of 2-bit Magnitude Comparator

| INPUT |       |       |       | OUTPUT  |         |         |
|-------|-------|-------|-------|---------|---------|---------|
| $A_1$ | $A_0$ | $B_1$ | $B_0$ | $A < B$ | $A = B$ | $A > B$ |
| 0     | 0     | 0     | 0     | 0       | 1       | 0       |
| 0     | 0     | 0     | 1     | 1       | 0       | 0       |
| 0     | 0     | 1     | 0     | 1       | 0       | 0       |
| 0     | 0     | 1     | 1     | 1       | 0       | 0       |
| 0     | 1     | 0     | 0     | 0       | 0       | 1       |
| 0     | 1     | 0     | 1     | 0       | 1       | 0       |
| 0     | 1     | 1     | 0     | 1       | 0       | 0       |
| 0     | 1     | 1     | 1     | 1       | 0       | 0       |
| 1     | 0     | 0     | 0     | 0       | 0       | 1       |
| 1     | 0     | 0     | 1     | 0       | 0       | 1       |
| 1     | 0     | 1     | 0     | 0       | 1       | 0       |
| 1     | 0     | 1     | 1     | 1       | 0       | 0       |
| 1     | 1     | 0     | 0     | 0       | 0       | 1       |
| 1     | 1     | 0     | 1     | 0       | 1       | 0       |
| 1     | 1     | 1     | 0     | 0       | 0       | 1       |
| 1     | 1     | 1     | 1     | 0       | 1       | 0       |

For  $A < B$   
 $X = \overline{A_1}B_1 + \overline{A_1}A_0\overline{B_0} + \overline{A_0}B_1B_0$

For  $A = B$   
 $Y = \overline{A_1}B_1 + \overline{A_1}A_0B_0 + A_1B_1 + A_1A_0B_0 + A_1\overline{A_0}B_1\overline{B_0}$

For  $A > B$   
 $Z = A_0\overline{B_1} + A_1A_0\overline{B_0} + A_1\overline{A_0}B_1$

$$\begin{aligned} Y &= \overline{A_1}B_1 + \overline{A_1}A_0\overline{B_0} + A_1B_1 + A_1A_0B_0 + A_1\overline{A_0}B_1\overline{B_0} \\ &= \overline{A_1}B_1(\overline{A_0}B_0 + A_0B_0) + A_1B_1(A_0B_0 + \overline{A_0}B_0) \\ &= \overline{A_1}B_1(A_0B_0) + A_1B_1(A_0\overline{B_0}) \\ &= (A_0\otimes B_0)(\overline{A}_1\otimes B_1) + (A_1\otimes B_1) \\ &= (A_0\otimes B_0)(A_1\otimes B_1) \end{aligned}$$

## Design of 2-bit Magnitude Comparator

For A &lt; B

$$X = \overline{A_1}B_1 + \overline{A_1}B_0\overline{A_0} + \overline{A_0}B_1B_0$$

For A = B

$$\begin{aligned} Y &= \overline{A_1}\overline{B_1}\overline{A_0}\overline{B_0} + \overline{A_1}A_0\overline{B_1}B_0 + A_1A_0B_1B_0 + A_1\overline{A_0}B_1\overline{B_0} \\ &= \overline{A_1}\overline{B_1}(\overline{A_0}\overline{B_0} + A_0B_0) + A_1B_1(A_0B_0 + \overline{A_0}\overline{B_0}) \\ &= \overline{A_1}\overline{B_1}(A_0 \odot B_0) + A_1B_1(A_0 \odot B_0) \\ &= (A_0 \odot B_0)(\overline{A_1}\overline{B_1} + A_1B_1) \\ &= (A_0 \odot B_0)(A_1 \odot B_1) \end{aligned}$$

For A &gt; B

$$Z = A_0\overline{B_1}\overline{B_0} + A_1A_0\overline{B_1} + A_1\overline{B_1}$$

Logic diagram of 2-bit Magnitude Comparator



## Design of 4-bit Magnitude Comparator

| A3B3  | A2B2  | A1B1  | A0B0  | A>B | A<B | A=B |
|-------|-------|-------|-------|-----|-----|-----|
| A3>B3 | x     | x     | x     | 1   | 0   | 0   |
| A3<B3 | x     | x     | x     | 0   | 1   | 0   |
| A3=B3 | A2>B2 | x     | x     | 1   | 0   | 0   |
| A3=B3 | A2<B2 | x     | x     | 0   | 1   | 0   |
| A3=B3 | A2=B2 | A1>B1 | x     | 1   | 0   | 0   |
| A3=B3 | A2=B2 | A1<B1 | x     | 0   | 1   | 0   |
| A3=B3 | A2=B2 | A1=B1 | A0>B0 | 1   | 0   | 0   |
| A3=B3 | A2=B2 | A1=B1 | A0<B0 | 0   | 1   | 0   |
| A3=B3 | A2=B2 | A1=B1 | A0=B0 | 0   | 0   | 1   |

The output A &gt; B logic expression can be written as

$$G = A_3\overline{B_3} + (A_3 \text{ Ex-NOR } B_3) A_2\overline{B_2} + (A_3 \text{ Ex-NOR } B_3) (A_2 \text{ Ex-NOR } B_2) A_1\overline{B_1} + (A_3 \text{ Ex-NOR } B_3) (A_2 \text{ Ex-NOR } B_2) (A_1 \text{ Ex-NOR } B_1) A_0\overline{B_0}$$

The logical expression for A &lt; B output can be written as

$$L = \overline{A_3}B_3 + (A_3 \text{ Ex-NOR } B_3) \overline{A_2}B_2 + (A_3 \text{ Ex-NOR } B_3) (A_2 \text{ Ex-NOR } B_2) \overline{A_1}B_1 + (A_3 \text{ Ex-NOR } B_3) (A_2 \text{ Ex-NOR } B_2) (A_1 \text{ Ex-NOR } B_1) \overline{A_0}B_0$$

The logical expression for A=B output can be written as

$$E = (A_3 \text{ Ex-NOR } B_3) (A_2 \text{ Ex-NOR } B_2) (A_1 \text{ Ex-NOR } B_1) (A_0 \text{ Ex-NOR } B_0)$$

## Design of 4-bit Magnitude Comparator

Let the two 4-bit numbers be  $A = A_3A_2A_1A_0$  and  $B = B_3B_2B_1B_0$

### Steps used in comparing two 4-bit numbers:

- First compare the two most significant bits ( $A_3$  and  $B_3$ ).  
If  $A_3 > B_3$ , then  $A > B$ ; if  $A_3 < B_3$ , then  $A < B$ .  
If  $A_3 = B_3$ , the next pair of bits ( $A_2$  and  $B_2$ ) must be compared.
- If  $A_3 = B_3$  and  $A_2 > B_2$ , then  $A > B$ ;  
if  $A_3 = B_3$  and  $A_2 < B_2$ , then  $A < B$   
if  $A_3 = B_3$  and  $A_2 = B_2$ , the next pair of bits ( $A_1$  and  $B_1$ ) will be compared.

- If  $A_3 = B_3$ ,  $A_2 = B_2$  and  $A_1 > B_1$ , then  $A > B$ ;  
if  $A_3 = B_3$ ,  $A_2 = B_2$  and  $A_1 < B_1$ , then  $A < B$ .  
if  $A_3 = B_3$ ,  $A_2 = B_2$  and  $A_1 = B_1$ , compare the LSBs ( $A_0$  and  $B_0$ ).
- If  $A_3 = B_3$ ,  $A_2 = B_2$ ,  $A_1 = B_1$  and  $A_0 > B_0$ , then  $A > B$ ;  
if  $A_3 = B_3$ ,  $A_2 = B_2$ ,  $A_1 = B_1$  and  $A_0 < B_0$ , then  $A < B$ .
- If  $A_3 = B_3$ ,  $A_2 = B_2$ ,  $A_1 = B_1$ ,  $A_0 = B_0$ , then  $A = B$ .

## Design of 4-bit Magnitude Comparator

The output A &gt; B logic expression can be written as

$$G = A_3\overline{B_3} + (A_3 \text{ Ex-NOR } B_3) A_2\overline{B_2} + (A_3 \text{ Ex-NOR } B_3) (A_2 \text{ Ex-NOR } B_2) A_1\overline{B_1} + (A_3 \text{ Ex-NOR } B_3) (A_2 \text{ Ex-NOR } B_2) (A_1 \text{ Ex-NOR } B_1) A_0\overline{B_0}$$

The logical expression for A &lt; B output can be written as

$$L = \overline{A_3}B_3 + (A_3 \text{ Ex-NOR } B_3) \overline{A_2}B_2 + (A_3 \text{ Ex-NOR } B_3) (A_2 \text{ Ex-NOR } B_2) \overline{A_1}B_1 + (A_3 \text{ Ex-NOR } B_3) (A_2 \text{ Ex-NOR } B_2) (A_1 \text{ Ex-NOR } B_1) \overline{A_0}B_0$$

The logical expression for A=B output can be written as

$$E = (A_3 \text{ Ex-NOR } B_3) (A_2 \text{ Ex-NOR } B_2) (A_1 \text{ Ex-NOR } B_1) (A_0 \text{ Ex-NOR } B_0)$$



Logic diagram of 4-bit Comparator

## MAGNITUDE COMPARATOR

❑ Magnitude Comparators are available in IC form.

❑ 7485 is a 4-bit magnitude comparator of the TTL logic family.



Logic Symbol



Pin Configuration

### Data Inputs

$$A = (A_3, A_2, A_1, A_0)_2$$

$$B = (B_3, B_2, B_1, B_0)_2$$

### Cascade Inputs

$$C1 \rightarrow A < B$$

$$C2 \rightarrow A = B$$

$$C3 \rightarrow A > B$$

### Outputs

$$O_{A>B}$$

$$O_{A<B}$$

$$O_{A=B}$$

Cascading inputs provide a means for expanding the comparison operation to more than four bits by cascading two or more four-bit comparators.

## MAGNITUDE COMPARATOR

### TRUTH TABLE

| COMPARING INPUTS                |                                 |                                 |                                 | CASCADED INPUTS     |                     |                  | OUTPUTS             |                     |                  |
|---------------------------------|---------------------------------|---------------------------------|---------------------------------|---------------------|---------------------|------------------|---------------------|---------------------|------------------|
| A <sub>3</sub> , B <sub>3</sub> | A <sub>2</sub> , B <sub>2</sub> | A <sub>1</sub> , B <sub>1</sub> | A <sub>0</sub> , B <sub>0</sub> | I <sub>A&gt;B</sub> | I <sub>A&lt;B</sub> | I <sub>A=B</sub> | O <sub>A&gt;B</sub> | O <sub>A&lt;B</sub> | O <sub>A=B</sub> |
| A <sub>3</sub> >B <sub>3</sub>  | X                               | X                               | X                               | X                   | X                   | X                | H                   | L                   | L                |
| A <sub>3</sub> <B <sub>3</sub>  | X                               | X                               | X                               | X                   | X                   | X                | L                   | H                   | L                |
| A <sub>3</sub> =B <sub>3</sub>  | A <sub>2</sub> >B <sub>2</sub>  | X                               | X                               | X                   | X                   | X                | H                   | L                   | L                |
| A <sub>3</sub> =B <sub>3</sub>  | A <sub>2</sub> <B <sub>2</sub>  | X                               | X                               | X                   | X                   | X                | L                   | H                   | L                |
| A <sub>3</sub> =B <sub>3</sub>  | A <sub>2</sub> =B <sub>2</sub>  | A <sub>1</sub> >B <sub>1</sub>  | X                               | X                   | X                   | X                | H                   | L                   | L                |
| A <sub>3</sub> =B <sub>3</sub>  | A <sub>2</sub> =B <sub>2</sub>  | A <sub>1</sub> <B <sub>1</sub>  | X                               | X                   | X                   | X                | L                   | H                   | L                |
| A <sub>3</sub> =B <sub>3</sub>  | A <sub>2</sub> =B <sub>2</sub>  | A <sub>1</sub> =B <sub>1</sub>  | A <sub>0</sub> >B <sub>0</sub>  | X                   | X                   | X                | H                   | L                   | L                |
| A <sub>3</sub> =B <sub>3</sub>  | A <sub>2</sub> =B <sub>2</sub>  | A <sub>1</sub> =B <sub>1</sub>  | A <sub>0</sub> <B <sub>0</sub>  | X                   | X                   | X                | L                   | H                   | L                |
| A <sub>3</sub> =B <sub>3</sub>  | A <sub>2</sub> =B <sub>2</sub>  | A <sub>1</sub> =B <sub>1</sub>  | A <sub>0</sub> =B <sub>0</sub>  | H                   | L                   | L                | H                   | L                   | L                |
| A <sub>3</sub> =B <sub>3</sub>  | A <sub>2</sub> =B <sub>2</sub>  | A <sub>1</sub> =B <sub>1</sub>  | A <sub>0</sub> =B <sub>0</sub>  | L                   | H                   | L                | H                   | L                   | L                |
| A <sub>3</sub> =B <sub>3</sub>  | A <sub>2</sub> =B <sub>2</sub>  | A <sub>1</sub> =B <sub>1</sub>  | A <sub>0</sub> =B <sub>0</sub>  | X                   | X                   | H                | L                   | L                   | H                |
| A <sub>3</sub> =B <sub>3</sub>  | A <sub>2</sub> =B <sub>2</sub>  | A <sub>1</sub> =B <sub>1</sub>  | A <sub>0</sub> =B <sub>0</sub>  | L                   | H                   | L                | L                   | H                   | L                |
| A <sub>3</sub> =B <sub>3</sub>  | A <sub>2</sub> =B <sub>2</sub>  | A <sub>1</sub> =B <sub>1</sub>  | A <sub>0</sub> =B <sub>0</sub>  | H                   | L                   | L                | L                   | L                   | L                |
| A <sub>3</sub> =B <sub>3</sub>  | A <sub>2</sub> =B <sub>2</sub>  | A <sub>1</sub> =B <sub>1</sub>  | A <sub>0</sub> =B <sub>0</sub>  | H                   | H                   | L                | L                   | L                   | L                |

H = HIGH Voltage Level  
L = LOW Voltage Level  
X = Immaterial

## MAGNITUDE COMPARATOR



(a) 74HC85 wired as a four-bit comparator



(b) Two 74HC85s cascaded to perform an eight-bit comparison

## MAGNITUDE COMPARATOR

Describe the operation of the eight-bit comparison arrangement in Figure for the following cases:

(a)  $A_7A_6A_5A_4A_3A_2A_1A_0 = 10101111; B_7B_6B_5B_4B_3B_2B_1B_0 = 10110001$

(b)  $A_7A_6A_5A_4A_3A_2A_1A_0 = 10101111; B_7B_6B_5B_4B_3B_2B_1B_0 = 10101001$

Solution:

a)  $O_{A<B}=1$

b)  $O_{A>B}=1$



Design a 5-bit comparator using a single 7485 and one gate.

The two 5-bit numbers to be compared are

$X_4 X_3 X_2 X_1 X_0$  and  $Y_4 Y_3 Y_2 Y_1 Y_0$



## Contents

6 hrs

- Binary Parallel Adder - Look ahead carry
- Magnitude Comparator
- Decoders
- Encoders
- Multiplexers
- Demultiplexers
  
- CO4: Analyze the operation of medium complexity standard combinational circuits like the encoder, decoder, multiplexer, demultiplexer.

## CSE1003 Digital Logic and Design Module 4 Combinational Circuits II L2

Dr. S.Hemamalini  
Professor  
School of Electrical Engineering  
VIT Chennai

## Binary Parallel Adder

- A binary parallel adder is a digital circuit that adds two binary numbers in parallel form and produces the arithmetic sum of those numbers in parallel form.
- It consists of full adders connected in a chain, with the output carry from each full-adder connected to the input carry of the next full-adder in the chain.
- An n-bit parallel adder requires n-Full adders.
- Practical Applications:
  1. It is used in Digital Processors
  2. ALU in computers and in calculators
  3. Different IC and microprocessor chips in PCs and laptops
  4. In Ripple counters
  5. Important tool in DSP (Digital Signal Processing)

## Binary Parallel Adder



## Binary Parallel Adder



## Binary Parallel Adder



## Binary Parallel Adder



The speed of parallel adder depends on the time required for the carries to propagate or ripple through all of the stages of the adder.

- Parallel adders suffer from propagation delay problem because higher bit additions depend on the carry generated from lower bit addition.
- The **carry propagation delay** for each full adder is the time between the application of the carry-in and the occurrence of the carry out.
- For an  $n$ -bit parallel adder, the total delay time is equal to  $n t_p$ , where  $t_p$  is the propagation delay of full-adder.
- The parallel adder in which the carry-out of each full adder is the carry-in to the next most significant adder is called a **ripple carry adder**.

## Binary Parallel Adder



Block symbol for cascading two 74HC283s

## Binary Parallel Adder

- How many inputs does a full adder have? How many outputs?

Ans: 3,2

- Assume the following input levels in Figure.

$$A_4 A_3 A_2 A_1 A_0 = 01001; \quad B_4 B_3 B_2 B_1 B_0 = 00111; \quad C_0 = 0$$

- (a) What are the logic levels at the outputs of FA #2?

$$\text{Ans: } S_2=0, C_3=1$$

- (b) What is the logic level at the C<sub>5</sub> output?

$$\text{Ans: } C_5=0$$

## Look ahead carry Adder

- The look-ahead carry adder speeds up the operation by eliminating the ripple carry delay.
- It examines all the input bits simultaneously and also generates the carry-in bits for all the stages simultaneously.
- It looks ahead and generate the carry for a certain given addition operation.
- The method of speeding up the addition process is based on the two additional functions of the full-adder, called the carry generate and carry propagate functions.

## Look ahead carry Adder



Logic diagram of a full adder

$$P_i = A_i \oplus B_i$$

$$G_i = A_i \cdot B_i$$

$$S_i = P_i \oplus C_i$$

$$C_{i+1} = P_i \cdot C_i + G_i$$

## Look ahead carry Adder

### Carry Generation

- Carry is generated only if both the input bits are 1, that is, if both the bits  $A$  and  $B$  are 1's, a carry has to be generated in this stage regardless of whether the input carry  $C_{in}$  is a 0 or a 1. Otherwise carry will not be generated.

Carry-generation function,  $G_i = A_i \cdot B_i$



## Look ahead carry Adder

### Carry Propagation

- A carry is propagated if any one of the two input bits  $A$  or  $B$  is 1.
- If both  $A$  and  $B$  are 0, a carry will never be propagated.
- On the other hand, if both  $A$  and  $B$  are 1, then it will not propagate the carry but will generate the carry.

$$P_i = A_i \oplus B_i$$

| Carry-generation and carry-propagation |     |          |         |           |  |
|----------------------------------------|-----|----------|---------|-----------|--|
| Inputs                                 |     |          | Outputs |           |  |
| $A$                                    | $B$ | $C_{in}$ | Sum     | $C_{out}$ |  |
| 0                                      | 0   | 0        | 0       | 0         |  |
| 0                                      | 0   | 1        | 1       | 0         |  |
| 0                                      | 1   | 0        | 1       | 0         |  |
| 0                                      | 1   | 1        | 0       | 1 □       |  |
| 1                                      | 0   | 0        | 1       | 0         |  |
| 1                                      | 0   | 1        | 0       | 1 □       |  |
| 1                                      | 1   | 0        | 0       | 1 ○       |  |
| 1                                      | 1   | 1        | 1       | 1 ○       |  |

□: Indicates carry propagated  
○: Indicates carry generated

## Look ahead carry Adder

CARRY output of each full adder stage in the four-bit binary adder

$$C_2 = G_1 + P_1 \cdot C_1$$

$$C_3 = G_2 + P_2 \cdot C_2 = G_2 + P_2 \cdot (G_1 + P_1 \cdot C_1) = G_2 + P_2 \cdot G_1 + P_1 \cdot P_2 \cdot C_1$$

$$C_4 = G_3 + P_3 \cdot C_3 = G_3 + P_3 \cdot (G_2 + P_2 \cdot G_1 + P_1 \cdot P_2 \cdot C_1)$$

$$C_4 = G_3 + P_3 \cdot G_2 + P_3 \cdot P_2 \cdot G_1 + P_1 \cdot P_2 \cdot P_3 \cdot C_1$$



## Look ahead carry Adder

### Four-bit full-adder with a look-ahead carry generator

$$C_2 = G_1 + P_1 \cdot C_1$$

$$C_3 = G_2 + P_2 \cdot C_2 = G_2 + P_2 \cdot (G_1 + P_1 \cdot C_1) = G_2 + P_2 \cdot G_1 + P_1 \cdot P_2 \cdot C_1$$

$$C_4 = G_3 + P_3 \cdot C_3 = G_3 + P_3 \cdot (G_2 + P_2 \cdot G_1 + P_1 \cdot P_2 \cdot C_1)$$

$$C_4 = G_3 + P_3 \cdot G_2 + P_3 \cdot P_2 \cdot G_1 + P_1 \cdot P_2 \cdot P_3 \cdot C_1$$



The circuit for look-ahead-carry introduces a delay corresponding to two gate levels.

## Look ahead carry Adder

Four-bit full adder with a look-ahead carry generator



## Look ahead carry Adder



Look-ahead carry generation for adding 64-bit numbers

## Look ahead carry Adder



IC 74182 interfaced with four four-bit adders

## Contents

6 hrs

- Binary Parallel Adder - Look ahead carry
- Magnitude Comparator
- **Decoders**
- Encoders
- Multiplexers
- Demultiplexers
- CO4: Analyze the operation of medium complexity standard combinational circuits like the encoder, decoder, multiplexer, demultiplexer.

## Decoders

*I/P:*  
 $A_3 \ A_2 \ A_1 \ A_0$   
 $2 \ 2 \ 2 \ 2$

### BASIC BINARY DECODER



## Decoders

- A **decoder** is a logic circuit that accepts a set of inputs that represents a binary number and activates only the output that corresponds to that input number.
- $N$  inputs and  $M$  outputs
- $2^N$  possible input combinations or codes



## Decoders

- Develop the logic required to detect the binary code 10010 and produce an active LOW output.

*I/P:*  
 $A_4 \ A_3 \ A_2 \ A_1 \ A_0$





3-to-8 decoder using 2-to-4 decoder

Expansion

MSB

| A<br>B<br>C | $Y_7$ | $Y_6$ | $Y_5$ | $Y_4$ | $Y_3$ | $Y_2$ | $Y_1$ | $Y_0$ |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0 0 0       | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1     |
| 0 0 1       | 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0     |
| 0 1 0       | 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0     |
| 0 1 1       | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0     |
| 1 0 0       | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0     |
| 1 0 1       | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0     |
| 1 1 0       | 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0     |
| 1 1 1       | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |



74LS139

## IMPLEMENTATION OF LOGIC EXPRESSIONS USING DECODERS

- Any combinational circuit with  $n$ -inputs and  $m$  outputs can be implemented with an  $n$ -to- $2^n$  decoder and OR gates.

## Procedure:

1. Express the given Boolean function in sum of minterms.

2. A decoder that generates all the minterms of the input variables is then chosen.

3. The inputs to each OR gate are selected from the decoder outputs according to the list of minterms of each function.



$$Y = A \cdot \bar{B} \cdot \bar{C} + \bar{A} \cdot B \cdot \bar{C} + A \cdot B \cdot C + \bar{A} \cdot \bar{B} \cdot \bar{C}$$

1 0 0      0 1 0      1 1 1      0 0 0

4      2      7      0

$$Y = \sum m(0, 2, 4, 7)$$

## 4-to-16 Decoder using 3-to-8 Decoder

| Binary Inputs |   |   |   | Decimal Output |
|---------------|---|---|---|----------------|
| A             | B | C | D | Active Low     |
| 0             | 0 | 0 | 0 | Y0             |
| 0             | 0 | 0 | 1 | Y1             |
| 0             | 0 | 1 | 0 | Y2             |
| 0             | 0 | 1 | 1 | Y3             |
| 0             | 1 | 0 | 0 | Y4             |
| 0             | 1 | 0 | 1 | Y5             |
| 0             | 1 | 1 | 0 | Y6             |
| 0             | 1 | 1 | 1 | Y7             |
| 1             | 0 | 0 | 0 | Y8             |
| 1             | 0 | 0 | 1 | Y9             |
| 1             | 0 | 1 | 0 | Y10            |
| 1             | 0 | 1 | 1 | Y11            |
| 1             | 1 | 0 | 0 | Y12            |
| 1             | 1 | 0 | 1 | Y13            |
| 1             | 1 | 1 | 0 | Y14            |
| 1             | 1 | 1 | 1 | Y15            |

Enable

A      Decoder 1      Decoder 2      Minterms  
 0      Enabled      Disabled      0000 to 0111  
 1      Disabled      Enabled      1000 to 1111



Implement a full adder circuit using a 3-to-8 line decoder.

Each output is a minterm  
 All minterms are produced  
 Sum the required minterms

| A | B | C | Inputs |   | Sum | Carry |
|---|---|---|--------|---|-----|-------|
|   |   |   | 0      | 1 |     |       |
| 0 | 0 | 0 | 0      | 0 | 0   | 0     |
| 0 | 0 | 1 | 1      | 0 | 1   | 0     |
| 0 | 1 | 0 | 1      | 1 | 0   | 1     |
| 0 | 1 | 1 | 0      | 1 | 1   | 0     |
| 1 | 0 | 0 | 0      | 1 | 1   | 0     |
| 1 | 0 | 1 | 0      | 0 | 0   | 1     |
| 1 | 1 | 0 | 1      | 0 | 0   | 1     |
| 1 | 1 | 1 | 1      | 1 | 1   | 1     |

$$\text{Sum output, } S = \sum 1, 2, 4, 7$$

$$\text{Carry output, } C_0 = \sum 3, 5, 6, 7$$



**CSE1003 Digital Logic and Design  
Module 4  
Combinational Circuits II**

**L4**

Dr. S.Hemamalini  
Professor  
School of Electrical Engineering  
VIT Chennai

**Contents**

6 hrs

- Binary Parallel Adder - Look ahead carry
- Magnitude Comparator
- Decoders
- **Encoders**
- Multiplexers
- Demultiplexers
- CO4: Analyze the operation of medium complexity standard combinational circuits like the encoder, decoder, multiplexer, demultiplexer.

**Encoders**

- An encoder is a combinational logic circuit that performs the inverse operation of a decoder.
- The process of converting various numbers (numerals, alphabets, special characters) into a binary format is called encoding.
- An encoder has  $2^n$  (or fewer) input lines and  $n$  output lines.
- The opposite of the decoding process is called encoding, i.e. encoding is a process of converting familiar numbers or symbols into a coded format.
- Binary encoders
  - Converts one of  $2^n$  inputs to an  $n$ -bit binary output
  - Useful for compressing data
  - Can be developed using AND/OR gates
- The simplest encoder is a  $2^n$ -to- $n$  binary encoder
  - One of  $2^n$  inputs = 1
  - Output is an  $n$ -bit binary number
- Commonly used encoders
  - Octal-to-binary encoder
  - Decimal-to-BCD encoder
  - Hexadecimal-to-binary encoder

**Block diagram of encoder****Contents**

6 hrs

**8-to-3 Binary Encoder or Octal-to-Binary Encoder**

Truth Table of an Octal to Binary Encoder

| Inputs         |                |                |                |                |                |                | Outputs        |                |                |                |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| I <sub>0</sub> | I <sub>1</sub> | I <sub>2</sub> | I <sub>3</sub> | I <sub>4</sub> | I <sub>5</sub> | I <sub>6</sub> | I <sub>7</sub> | Y <sub>2</sub> | Y <sub>1</sub> | Y <sub>0</sub> |
| 1              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              |
| 0              | 1              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 1              |
| 0              | 0              | 1              | 0              | 0              | 0              | 0              | 0              | 0              | 1              | 0              |
| 0              | 0              | 0              | 1              | 0              | 0              | 0              | 0              | 0              | 1              | 1              |
| 0              | 0              | 0              | 0              | 1              | 0              | 0              | 0              | 1              | 0              | 0              |
| 0              | 0              | 0              | 0              | 0              | 1              | 0              | 0              | 1              | 0              | 1              |
| 0              | 0              | 0              | 0              | 0              | 0              | 1              | 0              | 1              | 1              | 0              |
| 0              | 0              | 0              | 0              | 0              | 0              | 0              | 1              | 1              | 1              | 1              |

**Block diagram of an octal to binary encoder**

### Decimal-to-BCD Encoder



| INPUTS |       |       |       |       |       |       |       |       |       | OUTPUTS |       |       |       |
|--------|-------|-------|-------|-------|-------|-------|-------|-------|-------|---------|-------|-------|-------|
| $Y_9$  | $Y_8$ | $Y_7$ | $Y_6$ | $Y_5$ | $Y_4$ | $Y_3$ | $Y_2$ | $Y_1$ | $Y_0$ | $A_3$   | $A_2$ | $A_1$ | $A_0$ |
| 0      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 0       | 0     | 0     | 0     |
| 0      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0       | 0     | 0     | 1     |
| 0      | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0       | 0     | 0     | 1     |
| 0      | 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0       | 0     | 0     | 1     |
| 0      | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0       | 0     | 1     | 0     |
| 0      | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0       | 0     | 1     | 0     |
| 0      | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0       | 1     | 0     | 0     |
| 0      | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0       | 1     | 0     | 1     |
| 0      | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0       | 1     | 1     | 0     |
| 0      | 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0       | 1     | 1     | 0     |
| 0      | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0       | 1     | 0     | 0     |
| 1      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 0       | 0     | 0     | 1     |



$$\begin{aligned}A_3 &= Y_8 + Y_9 \\A_2 &= Y_4 + Y_5 + Y_6 + Y_7 \\A_1 &= Y_2 + Y_3 + Y_6 + Y_7 \\A_0 &= Y_1 + Y_3 + Y_5 + Y_7 + Y_9\end{aligned}$$

### Priority Encoders

#### 4-to-2 line Priority Encoder

- the higher the subscript number, the higher the priority of the input.



V = Valid bit indicator  
 V=1 more than 1 if line goes H to H  
 V=0 when all lines are zero

| $Y_3Y_2$ | 00 | 01 | 11 | 10 |
|----------|----|----|----|----|
| 00       | X  | 0  | 0  | 0  |
| 01       | 1  | 1  | 1  | 1  |
| 11       | 1  | 1  | 1  | 1  |
| 10       | 1  | 1  | 1  | 1  |

$A_1 = Y_3 + Y_2$   
 $A_0 = Y_3 + Y_2 \cdot Y_1$   
 $V = Y_3 + Y_2 + Y_1 + Y_0$



| INPUTS |       |       |       | OUTPUTS |       |   |  |
|--------|-------|-------|-------|---------|-------|---|--|
| $Y_3$  | $Y_2$ | $Y_1$ | $Y_0$ | $A_1$   | $A_0$ | V |  |
| 0      | 0     | 0     | 0     | X       | x     | 0 |  |
| 0      | 0     | 0     | 1     | 0       | 0     | 1 |  |
| 0      | 0     | 1     | X     | 0       | 1     | 1 |  |
| 0      | 1     | X     | X     | 1       | 0     | 1 |  |
| 1      | X     | X     | X     | 1       | 1     | 1 |  |

### Priority Encoders

- A priority encoder generates a binary code corresponding to the number of the active input with highest priority (or, most often, the highest number).
- It can be used in the following applications:
  - keyboard encoder: when several keys are pressed simultaneously, only the key with the highest number is taken into consideration;
  - unit processing interrupt requests in a microprocessor: in case of simultaneous interrupt requests, only the request with the highest priority is accepted.

- What if more than one input line has a value of 1?
- Ignore "lower priority" inputs.

74148, 74LS148, and 74HC148 are all octal-to-binary priority encoders.



8-to-3 priority encoder IC 74148

| EI | INPUTS |   |   |   |   |   |   | OUTPUTS |    |    |    |    |    |
|----|--------|---|---|---|---|---|---|---------|----|----|----|----|----|
|    | 0      | 1 | 2 | 3 | 4 | 5 | 6 | 7       | A2 | A1 | A0 | GS | EO |
| H  | X      | X | X | X | X | X | X | X       | H  | H  | H  | H  | H  |
| L  | H      | H | H | H | H | H | H | H       | H  | H  | H  | H  | L  |
| L  | X      | X | X | X | X | X | X | X       | L  | L  | L  | L  | H  |
| L  | X      | X | X | X | X | X | X | X       | L  | L  | L  | L  | H  |
| L  | X      | X | X | X | X | X | X | X       | L  | H  | L  | L  | H  |
| L  | X      | X | X | X | X | X | X | X       | L  | H  | H  | L  | H  |
| L  | X      | X | X | X | X | X | X | X       | L  | H  | H  | L  | H  |
| L  | X      | X | X | X | X | X | X | X       | L  | H  | H  | L  | H  |
| L  | X      | X | X | X | X | X | X | X       | L  | H  | H  | L  | H  |
| L  | X      | X | X | X | X | X | X | X       | L  | H  | H  | L  | H  |
| L  | L      | H | H | H | H | H | H | H       | H  | H  | H  | L  | H  |



## Decimal-to-BCD Encoder



| $\bar{A}_1$ | $\bar{A}_2$ | $\bar{A}_3$ | $\bar{A}_4$ | $\bar{A}_5$ | $\bar{A}_6$ | $\bar{A}_7$ | $\bar{A}_8$ | $\bar{A}_9$ | $\bar{O}_3$ | $\bar{O}_2$ | $\bar{O}_1$ | $\bar{O}_0$ |
|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|
| 1           | 1           | 1           | 1           | 1           | 1           | 1           | 1           | 1           | 1           | 1           | 1           | 1           |
| X           | X           | X           | X           | X           | X           | X           | X           | 0           | 0           | 1           | 1           | 0           |
| X           | X           | X           | X           | X           | X           | X           | 0           | 1           | 0           | 1           | 1           | 1           |
| X           | X           | X           | X           | X           | X           | 0           | 1           | 1           | 1           | 0           | 0           | 0           |
| X           | X           | X           | X           | X           | 0           | 1           | 1           | 1           | 1           | 0           | 0           | 1           |
| X           | X           | X           | X           | 0           | 1           | 1           | 1           | 1           | 1           | 0           | 1           | 0           |
| X           | X           | X           | 0           | 1           | 1           | 1           | 1           | 1           | 1           | 0           | 1           | 0           |
| X           | X           | 0           | 1           | 1           | 1           | 1           | 1           | 1           | 1           | 1           | 0           | 0           |
| 0           | 1           | 1           | 1           | 1           | 1           | 1           | 1           | 1           | 1           | 1           | 1           | 0           |

## Encoder Application (Monitoring Unit)

Encoder identifies the requester and encodes the value

Controller accepts digital inputs.



## Encoder Applications

1. Keyboard encoder for computers
2. Optical encoders – linear or rotary
3. Interfacing peripherals to microprocessors
4. Audio/video coding and transmission

## CSE1003 Problems

Design a logic circuit that has three inputs, A, B, and C, and whose output will be HIGH only when a majority of the inputs are HIGH.

**Step 1.** Set up the truth table.

| A | B | C | x |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 0 |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 1 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 1 |

**Step 2.** Write the AND term for each case where the output is a 1.

**Step 3.** Write the sum-of-products expression for the output.

$$x = \overline{ABC} + \overline{A}\overline{B}C + A\overline{B}\overline{C} + ABC$$

**Step 4.** Simplify the output expression.

$$x = BC + AC + AB$$

**Step 5.** Implement the circuit for the final expression.



- In a simple copy machine, a stop signal, S, is to be generated to stop the machine operation and energize an indicator light whenever either of the following conditions exists: (1) there is no paper in the paper feeder tray; or (2) the two microswitches in the paper path are activated, indicating a jam in the paper path. The presence of paper in the feeder tray is indicated by a HIGH at logic signal P. Each of the microswitches produces a logic signal (Q and R) that goes HIGH whenever paper is passing over the switch to activate it. Design the logic circuit to produce a HIGH at output signal S for the stated conditions, and implement it using the 74HC00 CMOS quad two-input NAND chip.



Variables: P, Q, R, S

| P | Q | R | S |
|---|---|---|---|
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | 1 |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 0 |
| 1 | 1 | 1 | 1 |

$S = \overline{P}\overline{Q}\overline{R} + \overline{P}\overline{Q}R + \overline{P}QR + PQR$

$S = \overline{P} + QR$

*Simplified Boolean expression*



Simplify  $f = A'B'C' + ABC' + ABC$  using maxterms using K-map method.



$$f = A'B'C' + ABC' + ABC$$

0 1 0 1 1 1 1

Using maxterms - place 0's in the remaining squares



Using minterms

The group of 0's provide the complement of the function

$$f = B'C' + AB \text{ SOP form}$$

$$\bar{F} = \bar{B} + \bar{A}C$$

$$F = \overline{\bar{F}} = \overline{\bar{B} + \bar{A}C} = \bar{B}(\bar{A} + \bar{C})$$

$$f = B(A + \bar{C}) \text{ POS form}$$



Simplify the following Boolean function into SOP & POS forms.

$$F(A, B, C) = \Sigma(0, 1, 3, 4, 5)$$

Fill in 1's in the squares of minterms for which  $F=1$  & fill in 0's in the remaining squares for which  $F=0$

Group of 1's provide the SOP form

Group of 0's provide the complement of the function

| A  | B | C | 0 | 1 |
|----|---|---|---|---|
| 00 | 1 | 1 | 1 | 1 |
| 01 | 0 | 1 | 1 | 1 |
| 11 | 0 | 0 | 1 | 1 |
| 10 | 1 | 0 | 1 | 1 |

Group of 1's - SOP form

$$F = \bar{B} + \bar{A}C$$

Group of 0's - complement of F

$$\bar{F} = B\bar{C} + AB$$

$$\begin{aligned} F = \bar{F} &= \overline{B\bar{C} + AB} = \overline{B\bar{C}} \cdot \overline{AB} \\ &= (\bar{B} + \bar{C}) \cdot (\bar{A} + \bar{B}) \\ &= (\bar{B} + C)(\bar{A} + \bar{B}) \end{aligned}$$

Give simplified logic equation of Table by QM method.

| A              | B | C | Y |
|----------------|---|---|---|
| m <sub>0</sub> | 0 | 0 | 0 |
| m <sub>1</sub> | 0 | 0 | 1 |
| m <sub>2</sub> | 0 | 1 | 0 |
| m <sub>3</sub> | 0 | 1 | 1 |
| m <sub>4</sub> | 1 | 0 | 0 |
| m <sub>5</sub> | 1 | 0 | 1 |
| m <sub>6</sub> | 1 | 1 | 0 |
| m <sub>7</sub> | 1 | 1 | 1 |

| Minterms       | Binary | Group | Stage 2 |     |                  |
|----------------|--------|-------|---------|-----|------------------|
|                |        |       | A       | B   | C                |
| m <sub>2</sub> | 0 1 0  | I     | 2, b    | -10 | P <sub>1</sub>   |
| m <sub>6</sub> | 1 1 0  | II    | 6, 7    | 11  | - P <sub>2</sub> |

$$m_7 \quad 1 \quad 1 \quad 1 \quad \text{III}$$

$$Y = B\bar{C} + AB$$

| Prime Implicant chart  |        |        |
|------------------------|--------|--------|
| 2, 6<br>P <sub>1</sub> | 2<br>✓ | 6<br>✓ |
| 6, 7<br>P <sub>2</sub> | 6<br>✓ | 7<br>✓ |

