## INF2270 — Spring 2010

Philipp Häfliger

### ecture 2: Boolean Functions, Combinational Logic



UNIVERSITETET I OSLO

Boolean Functions Leftover from Last Lecture Simplification with Karnaugh Maps

Combinational Logic Circuits Concepts Encoder/Decoder Multiplexer/Demultiplexer

Lecture 2: Boolean Functions, Combinational Logic



NIVERSITETET OSLO

### Boolean Functions Leftover from Last Lecture Simplification with Karnaugh Maps

Combinational Logic Circuits Concepts Encoder/Decoder Multiplexer/Demultiplexer

Lecture 2: Boolean Functions, Combinational Logic





#### Boolean Functions Leftover from Last Lecture Simplification with Karnaugh Maps

#### **Combinational Logic Circuits**

Concepts Encoder/Decoder Multiplexer/Demultiplexer

Lecture 2: Boolean Functions, Combinational Logic





NIVERSITETET OSLO

### **Representing Boolean Functions**

- 1. expression with variables and operators
- 2. truth table
- 3. graphically with logic gates (combinational logic)



Lecture 2: Boolean Functions, Combinational Logic



## **Examples: simplify**

## Solutions

|   | $a \wedge b \lor a \wedge \bar{b}$ |
|---|------------------------------------|
| = | a∧(b∨b̄)                           |
| = | $a \wedge 1$                       |
| = | а                                  |

|   | $a \wedge b \wedge c  \lor  \bar{a} \wedge b \wedge c$ | $\vee$ | $\bar{a} \wedge b \wedge \bar{c} \wedge (a \lor c)$ |
|---|--------------------------------------------------------|--------|-----------------------------------------------------|
| = | $(a \lor \bar{a}) \land b \land c$                     | $\vee$ | ā∧b∧ī∧a ∨ ā∧b∧ī∧c                                   |
| = | $1 \wedge b \wedge c$                                  | $\vee$ | 0 \vee 0                                            |
| = | $\mathbf{b}\wedge\mathbf{c}$                           |        |                                                     |

Lecture 2: Boolean Functions, Combinational Logic



**Solution** 

 $F{=}a{\wedge}b\,\vee\,\bar{a}\,\wedge\,\bar{b}$ 



Lecture 2: Boolean Functions, Combinational Logic



UNIVERSITETET I OSLO

**Solution** 

 $F{=}a{\wedge}b\,\vee\,\bar{a}\,\wedge\,\bar{b}$ 



Lecture 2: Boolean Functions, Combinational Logic



UNIVERSITETET I OSLO

**Solution** 

 $F{=}a{\wedge}b\,\vee\,\bar{a}\,\wedge\,\bar{b}$ 



Lecture 2: Boolean Functions, Combinational Logic



UNIVERSITETET I OSLO

**Solution** 

 $F{=}a{\wedge}b\,\vee\,\bar{a}\,\wedge\,\bar{b}$ 



Lecture 2: Boolean Functions, Combinational Logic



UNIVERSITETET I OSLO

Solution

 $F{=}a{\wedge}b\,\vee\,\bar{a}\,\wedge\,\bar{b}$ 



Lecture 2: Boolean Functions, Combinational Logic



UNIVERSITETET I OSLO

Solution

 $F{=}a{\wedge}b\,\vee\,\bar{a}\,\wedge\,\bar{b}$ 



Lecture 2: Boolean Functions, Combinational Logic



UNIVERSITETET I OSLO

### solution

 $G=a \wedge b \wedge c \lor \bar{a} \wedge c \lor a \land \bar{b}$ 



Lecture 2: Boolean Functions, Combinational Logic

C I

UNIVERSITETET I OSLO

### solution

 $G=a \wedge b \wedge c \lor \bar{a} \wedge c \lor a \land \bar{b}$ 



Lecture 2: Boolean Functions, Combinational Logic



UNIVERSITETET I OSLO

### solution

 $G=a \wedge b \wedge c \lor \bar{a} \wedge c \lor a \land \bar{b}$ 



Lecture 2: Boolean Functions, Combinational Logic



### solution

 $G=a \wedge b \wedge c \lor \bar{a} \wedge c \lor a \land \bar{b}$ 



Lecture 2: Boolean Functions, Combinational Logic



UNIVERSITETET I OSLO

### solution

 $G=a \wedge b \wedge c \lor \bar{a} \wedge c \lor a \land \bar{b}$ 



Lecture 2: Boolean Functions, Combinational Logic



UNIVERSITETET I OSLO

### solution

 $G=a \wedge b \wedge c \lor \bar{a} \wedge c \lor a \land \bar{b}$ 





#### Boolean Functions Leftover from Last Lecture Simplification with Karnaugh Maps

### **Combinational Logic Circuits**

Concepts Encoder/Decoder Multiplexer/Demultiplexer

Lecture 2: Boolean Functions, Combinational Logic



## **Simplification Example 2 Revisited**

#### $\mathbf{F} = \mathbf{a} \wedge \mathbf{b} \wedge \mathbf{c} \vee \mathbf{\bar{a}} \wedge \mathbf{b} \wedge \mathbf{c} \vee \mathbf{\bar{a}} \wedge \mathbf{b} \wedge \mathbf{\bar{c}} \wedge (\mathbf{a} \vee \mathbf{c})$

Lecture 2: Boolean Functions, Combinational Logic



UNIVERSITETET OSLO

|   | a | b | С | F |  |
|---|---|---|---|---|--|
|   | 0 | 0 | 0 | 0 |  |
|   | 0 | 0 | 1 | 0 |  |
| _ | 0 | 1 | 0 | 0 |  |
|   | 0 | 1 | 1 | 1 |  |
|   | 1 | 0 | 0 | 0 |  |
|   | 1 | 0 | 1 | 0 |  |
|   | 1 | 1 | 0 | 0 |  |
|   | 1 | 1 | 1 | 1 |  |

## Transscribing a Truth Table into a K-Map

| a | b | С | F |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 0 |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 0 |
| 1 | 1 | 1 | 1 |



The input variables are listed on the xand y-axis as Gray-code: only one bit shift between two subsequent positions.



## Identify the 'minterms'

Identify rectangles filled with 1's and containing  $2^n$  1's (i.e. 1,2,4,8 ... elements). Find a set of a minimal number of such rectangles that covers all 1's. Overlap of the rectangles is allowed, actually desired to maximize their size. Note that the K-map wraps around at its boundaries, i.e rectangles can be formed across the map edges.



Lecture 2: Boolean Functions, Combinational Logic



## The minterms define a 'sum' of 'products'



(b ∧ c)

Each rectangle defines a 'product' (elements and-ed) where the elements are the input variables that remain *constant* within the rectangle. Finally, all 'products' are or-ed. (Note: there is only one 'product' in this first example. See next example!)

Lecture 2: Boolean Functions, Combinational Logic





Lecture 2: Boolean Functions, Combinational Logic



UNIVERSITETET I OSLO



(a)

Lecture 2: Boolean Functions, Combinational Logic





 $a \vee (\bar{b} \wedge \bar{d})$ 

Lecture 2: Boolean Functions, Combinational Logic



UNIVERSITETET I OSLO





 $a \ \lor \ \bar{b} \land \bar{d} \ \lor \ (b \land \bar{c} \land d)$ 

Lecture 2: Boolean Functions, Combinational Logic



UNIVERSITETET I OSLO

## K-Maps Based on the '0's

One can also use the 0 to form the minterms and derive an expression for the inverse function  $\overline{F}$  instead of F by exact same procedure. Then one can use the deMorgan theorem to turn the sum of product into a product of sums to derive F.

Lecture 2: Boolean Functions, Combinational Logic



## **Properties of K-maps**

- Karnaugh maps are useful to a size of up to 6 Boolean variables
- It is only possible to have up to two variables along one axis. Karnaugh maps with 5-8 variables become, thus, 3-dimensional. (Example in the weekly exercise for lecture 3)

Lecture 2: Boolean Functions, Combinational Logic



Boolean Functions Leftover from Last Lecture Simplification with Karnaugh Maps

Combinational Logic Circuits Concepts Encoder/Decoder Multiplexer/Demultiplexer

Lecture 2: Boolean Functions, Combinational Logic



NIVERSITETET OSLO

#### **Boolean Functions**

Leftover from Last Lecture Simplification with Karnaugh Maps

#### Combinational Logic Circuits Concepts Encoder/Decoder Multiplexer/Demultiplexer

Lecture 2: Boolean Functions, Combinational Logic



NIVERSITETET OSLO

## **Combinational Logic**

Combinational logic circuits are feed-forward logic/digital circuits with no memory that can be described by Boolean functions.

Note what is implied here: logic gates can *also* be connected in ways that include feed-back connections that implement/include *memory* that *cannot* be described as Boolean functions! This is then not 'combinational logic', but 'sequential logic', of which we will talk later.

## **Design and Analysis of Digital Circuits**

Design of a digital circuit is the process of assembling circuit blocks to form a bigger digital circuit.

Analysis of a digital circuit is the process of finding out what it is doing, e.g. (in the case of combinational logic!) by finding an equivalent Boolean function or a complete truth table.



A complete analysis is quite trivial for small digital circuits but neigh impossible for circuits of the complexity of a modern CPU. Hierarchical approaches in design and analysis provide some help.

The first Pentium on the market had a mistake in its floating point unit.

After the Intel 286 there was the 386 and then the 486, but the 585.764529 was then dubbed 'Pentium' for simplicity sake.



## **Logic Gate Signals**

The logic gates introduced earlier are most often implemented to operate on voltages as input and output signals: a certain range of input voltage is defined as 'high' or logic '1' and another range is defined as 'low' or '0'. E.g. in a digital circuit with a 1.8V supply one can, for instance, guarantee an input voltage of 0V to 0.5V to be recognised as '0' and 1.2V to 1.8V as '1' by a logic gate. On the output side the gate can guarantee to deliver a voltage of either >1.75V or <0.05V.

These safety margins between input and output make (correctly designed!) digital circuits very robust (which is necessary with millions of logic gates in a CPU, where a single error might impair the global function!)

Lecture 2: Boolean Functions, Combinational Logic





## **Combinational Logic Analysis: Example**



Lecture 2: Boolean Functions, Combinational Logic

U I

UNIVERSITETET I OSLO

Any Boolean function can also be implemented using only NAND (or only NOR) gates. Use  $\overline{a \wedge b} = \overline{a} \vee \overline{b}$  (deMorgan) and  $\overline{\overline{a}} = a$  to proof!





Any Boolean function can also be implemented using only NAND (or only NOR) gates. Use  $\overline{a \wedge b} = \overline{a} \vee \overline{b}$  (deMorgan) and  $\overline{\overline{a}} = a$  to proof!



Lecture 2: Boolean Functions, Combinational Logic



Any Boolean function can also be implemented using only NAND (or only NOR) gates. Use  $\overline{a \wedge b} = \overline{a} \vee \overline{b}$  (deMorgan) and  $\overline{\overline{a}} = a$  to proof!



Lecture 2: Boolean Functions, Combinational Logic



Any Boolean function can also be implemented using only NAND (or only NOR) gates. Use  $\overline{a \wedge b} = \overline{a} \vee \overline{b}$  (deMorgan) and  $\overline{\overline{a}} = a$  to proof!



Lecture 2: Boolean Functions, Combinational Logic



# **Standard Combinational Logic**

Some combinational logic (and of course also sequential logic  $\rightarrow$  later) is often used in computational devices and are usually provided as 'black boxes' guaranteeing a defined function.

Examples:

- encoder/decoder
- multiplexer/demultiplexer
- adders/multipliers

There are actually variations on how those functions are implemented, resulting in different processing speeds and/or power consumption and/or scalability (i.e. how easy it is to adapt the same function for more inputs). Lecture 2: Boolean Functions, Combinational Logic



#### content

#### **Boolean Functions**

Leftover from Last Lecture Simplification with Karnaugh Maps

#### **Combinational Logic Circuits**

Concepts Encoder/Decoder Multiplexer/Demultiplexe

Lecture 2: Boolean Functions, Combinational Logic



## **3-bit Encoder Specification**

An encoder in digital electronics usually refers to a circuit that converts  $2^n$  inputs into n outputs, as specified by the following truth table.



Lecture 2: Boolean Functions, Combinational Logic



## Simple 3-bit Encoder Truth Table

| $I_7$ | $I_6$ | $I_5$ | $I_4$ | $I_3$ | $I_2$ | $I_1$ | $I_0$ | <i>O</i> <sub>2</sub> | 01 | <i>O</i> <sub>0</sub> |
|-------|-------|-------|-------|-------|-------|-------|-------|-----------------------|----|-----------------------|
| 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 0                     | 0  | 0                     |
| 0     | 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0                     | 0  | 1                     |
| 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0                     | 1  | 0                     |
| 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0                     | 1  | 1                     |
| 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 1                     | 0  | 0                     |
| 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0     | 1                     | 0  | 1                     |
| 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 1                     | 1  | 0                     |
| 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1                     | 1  | 1                     |

Lecture 2: Boolean Functions, Combinational Logic



## **3-bit Encoder Implementation Variant**



Lecture 2: Boolean Functions, Combinational Logic





## **3-bit Encoder Remarks**

The truth table that was given is not complete: some inputs are 'illegal'. Circuitry that produces the input should ensure to only produce legal states. In our specific digital circuit implementation we can of course deduct what the output in each illegal case would be, but other implementation may actually provide different outputs in those non-defined cases, and still be valid encoders! The following truth table is a deterministic specification of an encoder, without 'illegal' inputs, where the 'highest' active input bit determines the output. 'X' in the table means 'do not care', or 'for any state' and allows to abbreviate the truth table. This would require a different implementation, but we will not present it here.

Lecture 2: Boolean Functions, Combinational Logic





## **3-bit Priority Encoder Truth Table**

| $I_7$ | $I_6$ | $I_5$ | $I_4$ | $I_3$ | I <sub>2</sub> | $I_1$ | $I_0$ | <i>O</i> <sub>2</sub> | 01 | <i>O</i> <sub>0</sub> |
|-------|-------|-------|-------|-------|----------------|-------|-------|-----------------------|----|-----------------------|
| 0     | 0     | 0     | 0     | 0     | 0              | 0     | 1     | 0                     | 0  | 0                     |
| 0     | 0     | 0     | 0     | 0     | 0              | 1     | Х     | 0                     | 0  | 1                     |
| 0     | 0     | 0     | 0     | 0     | 1              | Х     | Х     | 0                     | 1  | 0                     |
| 0     | 0     | 0     | 0     | 1     | Х              | Х     | X     | 0                     | 1  | 1                     |
| 0     | 0     | 0     | 1     | Х     | X              | Х     | Х     | 1                     | 0  | 0                     |
| 0     | 0     | 1     | Х     | Х     | Х              | Х     | Х     | 1                     | 0  | 1                     |
| 0     | 1     | Х     | Х     | Х     | Х              | Х     | Χ     | 1                     | 1  | 0                     |
| 1     | Х     | Х     | Х     | Х     | Х              | Х     | Х     | 1                     | 1  | 1                     |

Lecture 2: Boolean Functions, Combinational Logic



# **3-bit Decoder Specification**

A decoder is the inverse function of a encoder, in digital circuits usually decoding n inputs into  $2^n$  outputs.





## **3-bit Decoder Truth Table**



Lecture 2: Boolean Functions, Combinational Logic





## **3-bit Decoder Implementation Variant**



Lecture 2: Boolean Functions, Combinational Logic



UNIVERSITETET I OSLO

#### content

#### **Boolean Functions**

Leftover from Last Lecture Simplification with Karnaugh Maps

#### **Combinational Logic Circuits**

Concepts Encoder/Decoder Multiplexer/Demultiplexer

Lecture 2: Boolean Functions, Combinational Logic



## **3-bit Multiplexer Specification**

A multiplexer routes one of  $2^n$  input signals as defined by the binary control number **S** to the output.



| the output.           |       |                       |                       |  |  |  |  |
|-----------------------|-------|-----------------------|-----------------------|--|--|--|--|
| <i>S</i> <sub>2</sub> | $S_1$ | <i>S</i> <sub>0</sub> | 0                     |  |  |  |  |
| 0                     | 0     | 0                     | $I_0$                 |  |  |  |  |
| 0                     | 0     | 1                     | $I_1$                 |  |  |  |  |
| 0                     | 1     | 0                     | $I_2$                 |  |  |  |  |
| 0                     | 1     | 1                     | $I_3$                 |  |  |  |  |
| 1                     | 0     | 0                     | $I_4$                 |  |  |  |  |
| 1                     | 0     | 1                     | $I_5$                 |  |  |  |  |
| 1                     | 1     | 0                     | $I_6$                 |  |  |  |  |
| 1                     | 1     | 1                     | <i>I</i> <sub>7</sub> |  |  |  |  |

Lecture 2: Boolean Functions, Combinational Logic



## **3-bit Multiplexer Implementation Variant**





## **3-bit Demultiplexer Specification**

A demultiplexer performs the inverse function of a multiplexer, routing one input signal to one of  $2^n$  outputs as defined by the binary control number **S** 



Lecture 2: Boolean Functions, Combinational Logic



# **3-bit Demultiplexer Truth Table**





### **3-bit Demultiplexer Implementation Variant**



Lecture 2: Boolean Functions, Combinational Logic



UNIVERSITETET I OSLO