# ITM1010 Computer and Communication Technologies Lecture #5 Part I: Introduction to Computer Technologies K-Map, Combination and Sequential Logic Circuits #### Product-Of-Sum Configuration Direct extraction of POS from truth table: - For each 0 of "F", write the corresponding term in the form of sum of complements of inputs. - "F" equals the product of the sums. | A | В | C | F | |---|---|---|---| | 0 | 0 | 0 | 0 | | 0 | 0 | 1 | 0 | | 0 | 1 | 0 | 1 | | 0 | 1 | 1 | 0 | | 1 | 0 | 0 | 0 | | 1 | 0 | 1 | 1 | | 1 | 1 | 0 | 0 | | 1 | 1 | 1 | 0 | $$F = (A + B + C)(A + B + \overline{C})(A + \overline{B} + \overline{C})(\overline{A} + B + C)(\overline{A} + \overline{B} + C)(\overline{A} + \overline{B} + \overline{C})$$ # 3-input K-map | | $\overline{C}$ | $\boldsymbol{C}$ | |-----------------|-----------------------------|------------------| | $\overline{AB}$ | $\overline{ABC}$ | $\overline{ABC}$ | | $\overline{A}B$ | $\overline{ABC}$ | $\overline{A}BC$ | | AB | $AB\overline{C}$ | ABC | | $A\overline{B}$ | $A\overline{B}\overline{C}$ | $A\overline{B}C$ | | | C | $\boldsymbol{C}$ | |-----------------|---|------------------| | $\overline{AB}$ | 0 | 0 | | $\overline{A}B$ | | | | AB | 0 | | | $A\overline{B}$ | 0 | 0 | Layout of a 3-input K-map based on Gray Code $$\overline{A}B+\overline{A}BC+ABC$$ $\overline{A}B+BC(\overline{A}+A)$ $\overline{A}B+BC(1)$ $\overline{A}B+BC$ $$\overline{A}\overline{B} + A\overline{B} + AB\overline{C} + A\overline{B}\overline{C}$$ $$\overline{B}(\overline{A} + A) + A\overline{C}(B + \overline{B})$$ $$\overline{B}(1) + A\overline{C}(1)$$ $$\overline{B} + A\overline{C}$$ # K-map: 4-input example $$BD + C\overline{D}$$ # K-Map Minimization Guideline - Loop all isolated 1s; - Consider each remaining 1 separately. If it can be looped in more than one way, try include it in the largest possible loop; - A minimal solution is derived as soon as all 1s are covered. In the process of making the largest loop, it is permissible to use previously covered 1s. #### Class Exercise Simplify the following logic function: | | $\overline{C}\overline{D}$ | $\overline{C}D$ | CD | $C\overline{D}$ | |----------------------------|----------------------------|-----------------|----|-----------------| | $\overline{A}\overline{B}$ | 1 | 0 | 0 | 1 | | $\overline{A}B$ | 0 | 0 | 0 | 0 | | AB | 1 | 0 | 0 | 1 | | $A\overline{B}$ | 1 | 0 | 0 | 1 | # Don't Care Condition in K-Map Certain combinations of inputs may be immaterial to a given function. For such don't care states the output is irrelevant and may be 1 or 0. X – don't care input condition If we use X=0, $F = \overline{ABC} + \overline{ABC} + \overline{ABC} + \overline{ABC} + \overline{ABC}$ This can be simplified (with X=0) to $F = \overline{AC} + \overline{ABC} + \overline{ABC}$ With K-map, 1 can be assigned to any don't care position to - form largest possible loop - Combine isolated 1 to form a loop - In the example we can further simplify the expression by taking the bottom X as 1: F = C + AB #### Design Example: Majority Detector Design a 4-input circuit that will function as a majority detector. The circuit should output high when a majority of the inputs are high. The first step is to complete a truth table and mark high outputs for every set of input conditions that contains three or four (majority) 1s. This is shown in the truth table on the right. | A | В | C | D | X | |---|---|---|---|---| | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | 1 | 0 | | 0 | 0 | 1 | 0 | 0 | | 0 | 0 | 1 | 1 | 0 | | 0 | 1 | 0 | 0 | 0 | | 0 | 1 | 0 | 1 | 0 | | 0 | 1 | 1 | 0 | 0 | | | | | | | | 1 | 0 | 0 | 0 | 0 | | 1 | 0 | 0 | 1 | 0 | | 1 | 0 | 1 | 0 | 0 | | | | | | | | 1 | 1 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | #### Design Example: Majority Detector | | | | | 1 | |---|---|---|---|---| | A | В | C | D | X | | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | 1 | 0 | | 0 | 0 | 1 | 0 | 0 | | 0 | 0 | 1 | 1 | 0 | | 0 | 1 | 0 | 0 | 0 | | 0 | 1 | 0 | 1 | 0 | | 0 | 1 | 1 | 0 | 0 | | 0 | 1 | 1 | 1 | 1 | | 1 | 0 | 0 | 0 | 0 | | 1 | 0 | 0 | 1 | 0 | | 1 | 0 | 1 | 0 | 0 | | 1 | 0 | 1 | 1 | 1 | | 1 | 1 | 0 | 0 | 0 | | 1 | 1 | 0 | 1 | 1 | | 1 | 1 | 1 | 0 | 1 | | 1 | 1 | 1 | 1 | 1 | Next, plot the Boolean expression from the truth table on a K-map as shown and simplify the expression. $$X = ABD + BCD + ABC + ACD$$ #### Design Example: Majority Detector The simplified expression is shown on the right, which has four terms since four pairs of 1s can be looped on the K-map. Implementation is straightforward as shown on the right because this is an SOP expression. The circuit requires four 3-input AND gates and one 4-input OR gate. $$X = ABD + BCD + ABC + ACD$$ # Types of Digital Networks - Combinational: The logic outputs at each instant are determined only by the inputs at that instant - Sequential: The logic output are dependent on the previous inputs as well as the present inputs When A=B=0, F may be either 0 or 1 depending on the previous input. # Common Combinational Logic Circuits #### Encoder A circuit converts a signal to a coded format. Example: Decimal to Binary Coded Decimal (BCD) encoder | Decimal signal lines | BCD | |----------------------|----------------| | | $b_3b_2b_1b_0$ | | 0 | 0000 | | 1 | 0001 | | 2 | 0010 | | 3 | 0 0 1 1 | | 4 | 0100 | | 5 | 0101 | | 6 | 0110 | | 7 | 0 1 1 1 | | 8 | 1000 | | 9 | 1001 | #### **BCD Invalid Sum Detector** | Decimal signal lines | BCD | |----------------------|----------------| | | $b_3b_2b_1b_0$ | | 0 | 0 0 0 0 | | 1 | 0 0 0 1 | | 2 | 0010 | | 3 | 0 0 1 1 | | 4 | 0100 | | 5 | 0101 | | 6 | 0110 | | 7 | 0111 | | 8 | 1000 | | 9 | 1001 | | Decimal signal lines | Invalid BCD $b_3b_2b_1b_0$ | |----------------------|----------------------------| | - | 1010 | | _ | 1011 | | _ | 1100 | | _ | 1 1 0 1 | | _ | 1110 | | _ | 1111 | # Invalid BCD numbers #### **BCD Invalid Sum Detector** | Invalid BCD $b_3b_2b_1b_0$ | | | | |----------------------------|--|--|--| | 1010 | | | | | 1011 | | | | | 1100 | | | | | 1 1 0 1 | | | | | 1 1 1 0 | | | | | 1 1 1 1 | | | | $$X = \mathbf{b}_3 \mathbf{b}_2 + \mathbf{b}_3 \mathbf{b}_1$$ ## Multiplexer Select one signal from two or more input lines and transmit it on a single output line. Example: 2-1 multiplexer # Multiplexer Example: n-1 multiplexer # Demultiplexer Recover multiplexed signals and transmit them to separate outputs. e.g. 4-channel demultiplexer #### Half Adder Add 2 bits and produce both a sum and a carry output | A | В | Sum | Carry | |---|---|-----|-------| | 0 | 0 | 0 | 0 | | 0 | 1 | 1 | 0 | | 1 | 0 | 1 | 0 | | 1 | 1 | 0 | 1 | #### Full Adder Sum of three bits: 2 data bits and a carry bit from lower bit addition | A | В | С | Sum | C <sub>out</sub> | |---|---|---|-----|------------------| | 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 | $$C_{OUT} = \overline{A}BC + A\overline{B}C + AB\overline{C} + ABC$$ $$C_{OUT} = AB + BC + AC$$ #### Building Full Adder from Half Adder #### Multi-bit adder circuits #### Parallel Adder Number of modules same as the word length #### Adder/Subtractor # Sequential Logic Circuits # Sequential Logic Circuits A sequential logic circuit's output depends on its previous state (condition) in addition to its current inputs. This is accomplished by using feedback from the circuit's outputs back to its inputs. When A=B=0, F may be either 0 or 1 depending on the previous input. #### Latch A latch circuit is a bistable device. *Bistable* indicates that the latch has two stable states. These two latch states are called the SET state and the CLEAR state. Once a latch is put in one of these states it will remain in that state until forced to change states by another input signal. There are two basic types of latch circuits: the NAND-gate latch and the NOR-gate latch. # NAND-gate Latch (b) LOGIC DIAGRAM USING ALTERNATE NAND GATE SYMBOLS # NOR-gate Latch #### Latches These latches are formed by using cross-coupled inverting logic gates. The cross coupling provides the feedback necessary for the latch circuit to retain (store) data. A latch constructed with NAND gates is referred to as an active-low latch, and a latch constructed with NOR gates is called an active-high latch. The active-low and active-high references are derived from the input logic level that must be applied to the latch to put it in a certain state. #### Latches A latch has two outputs. One is labeled Q. The other output, which is the complement of Q, is labeled Q. A latch can have only two valid output conditions. One is the SET state, where output Q = 1 and Q = 0. The other condition is the CLEAR state, where Q = 0 and Q = 1. Since the latch is designed to normally have complementary outputs (Q and Q), it is only necessary to remember that Q is high in the SET state and Q is low in the CLEAR state. #### Latches Q of course, will normally be the opposite level of Q, The Q output is a convenience for circuit designers, is often not used in digital circuits, and is sometimes not available as an output on a flipflop IC. The CLEAR state is also referred to as the RESET state. The latches are sometimes called S-C (SET-CLEAR) latches or S-R (SET-RESET) latches. Since a latch only has a SET state or a CLEAR state, it can store only one bit of data. Latch circuits are typically used to store binary information on a temporary basis. #### State Table - SET State A latch must be put in a SET state to store a binary 1 data bit at the *Q* output. #### State Table - CLEAR State A latch must be put in a CLEAR state to store a binary 0 at the *Q* output. #### State Table – RETAIN State The two logic 1s applied to this latch cause it to retain the condition it was in when the two inputs were brought high (inactive). #### State Table – INVALID State For a NAND gate, 0s into each logic gate will produce a 1 out of each gate. Equal outputs are considered INVALID. # Active-Low Latch Operation #### **Active-Low Latch** | SET | CLR | Q | $\bar{\varrho}$ | STATE | |-----|-----|----|-----------------|---------| | 0 | 1 | 1 | 0 | SET | | 1 | 0 | 0 | 1 | CLEAR | | 1 | 1 | 10 | 0 1 | RETAIN | | 0 | 0 | 1 | 1 | INVALID | (b) STATE TABLE # Active-High Latch