#### The Design And Analysis of Combinational Logic Circuits Analysis 1 Analysis 2 Design 1 Please design a three-person voting machine. Design 2 Half-adder and Full-adder Parallel Binary Adders The Look-Ahead Carry Adder Comparators (Design a 2-bit comparator) **Decoders** The 4-Bit Decoder Design voting machine via 74HC154 The BCD-to-Decimal Decoder The BCD-to-7-Segment Decoder **Encoders** The Decimal-to-BCD Encoder Multiplexers (Data Selectors) Use Slector to design a voting machine Demultiplexers # The Design And Analysis of Combinational Logic Circuits # **Analysis 1** #### **EXAMPLE 5-7** Reduce the combinational logic circuit in Figure 5–14 to a minimum form. #### **FIGURE 5-14** Open file F05-14 to verify that this circuit is equivalent to the gate in Figure 5–15. #### **MultiSim** ### **Analysis 2** Y=A+B hutf-Adder A B Y Co Y=AB+AB $$=$$ A PB S O O O Co=AB **Design 2 Half-adder and Full-adder** ## **Parallel Binary Adders** As $$\frac{1}{3}$$ $\frac{1}{3}$ $\frac{1}{3}$ $\frac{1}{4}$ $\frac$ $$= (\overline{A}B + A\overline{B}) (\overline{i}$$ $$+ (\overline{A}B + A\overline{B}) (\overline{i})$$ $$= (\overline{A}B + A\overline{B}) (\overline{i}) | A\overline{B}$$ $$+ (\overline{A}B + A\overline{B}) (\overline{i}) | A\overline{B}$$ $$+ (\overline{A}B + A\overline{B}) (\overline{i}) | A\overline{B}$$ $$= (\overline{A}BB) (\overline{i}) | A\overline{B}B | C\overline{i}$$ $$= (\overline{A}BB) (\overline{i}) | A\overline{B}B | C\overline{i}$$ $$= (\overline{A}BB) (\overline{i}) | A\overline{B}B | C\overline{i}$$ $$C_{0} = ABC_{1}' + \overline{ABC_{1}'} + \overline{ABC_{1}'} + \overline{ABC_{1}'}$$ $$= AB + (ABB)C_{1}'$$ $$= AB + (ABB)C_{1}'$$ $$ABBC_{1}'$$ $$ABC_{1}'$$ $$ACC_{1}'$$ $$AC$$ **FIGURE 6–14** A 4-bit parallel ripple carry adder showing "worst-case" carry propagation delays. ### **IMPLEMENTATION: 4-BIT PARALLEL ADDER** **Fixed-Function Device** The 74HC283 and the 74LS283 are 4-bit parallel adders with identical package pin configurations. The logic symbol and package pin configuration are shown in Figure 6–10. Go to *ti.com* for data sheet information. FIGURE 6-10 The 74HC283/74LS283 4-bit parallel adder. ### Adder Expansion The 4-bit parallel adder can be expanded to handle the addition of two 8-bit numbers by using two 4-bit adders. The carry input of the low-order adder ( $C_0$ ) is connected to ground because there is no carry into the least significant bit position, and the carry output of the low-order adder is connected to the carry input of the high-order adder, as shown in Figure 6–11. This process is known as **cascading**. Notice that, in this case, the output carry is designated $C_8$ because it is generated from the eighth bit position. The low-order adder is FIGURE 6-11 Cascading of two 4-bit adders to form an 8-bit adder. FIGURE 6-13 A voting system using full-adders and parallel binary adders. # The Look-Ahead Carry Adder #### Full-adder 1: $$C_{\text{out1}} = C_{g1} + C_{p1}C_{\text{in1}}$$ #### Full-adder 2: $$C_{\text{in2}} = C_{\text{out1}}$$ $$C_{\text{out2}} = C_{g2} + C_{p2}C_{\text{in2}} = C_{g2} + C_{p2}C_{\text{out1}} = C_{g2} + C_{p2}(C_{g1} + C_{p1}C_{\text{in1}})$$ $$= C_{g2} + C_{p2}C_{g1} + C_{p2}C_{p1}C_{\text{in1}}$$ #### Full-adder 3: $$\begin{split} C_{\text{in3}} &= C_{\text{out2}} \\ C_{\text{out3}} &= C_{g3} + C_{p3}C_{\text{in3}} = C_{g3} + C_{p3}C_{\text{out2}} = C_{g3} + C_{p3}(C_{g2} + C_{p2}C_{g1} + C_{p2}C_{p1}C_{\text{in1}}) \\ &= C_{g3} + C_{p3}C_{g2} + C_{p3}C_{p2}C_{g1} + C_{p3}C_{p2}C_{p1}C_{\text{in1}} \end{split}$$ #### Full-adder 4: $$\begin{split} C_{\text{in4}} &= C_{\text{out3}} \\ C_{\text{out4}} &= C_{g4} + C_{p4}C_{\text{in4}} = C_{g4} + C_{p4}C_{\text{out3}} \\ &= C_{g4} + C_{p4}(C_{g3} + C_{p3}C_{g2} + C_{p3}C_{p2}C_{g1} + C_{p3}C_{p2}C_{p1}C_{\text{in1}}) \\ &= C_{g4} + C_{p4}C_{g3} + C_{p4}C_{p3}C_{g2} + C_{p4}C_{p3}C_{p2}C_{g1} + C_{p4}C_{p3}C_{p2}C_{p1}C_{\text{in1}} \end{split}$$ FIGURE 6-17 Logic diagram for a 4-stage look-ahead carry adder. ### **Comparators** (Design a 2-bit comparator) #### **EXAMPLE 6-6** Determine the A = B, A > B, and A < B outputs for the input numbers shown on the comparator in Figure 6–22. FIGURE 6-22 | $\bigcirc$ | | 0 | 0 | |------------|------------|------------|------------------------| | $\bigcirc$ | | 0 | | | | | | $\widehat{\mathbb{Q}}$ | | $\bigcirc$ | | | | | | 0 | $\bigcirc$ | 0 | | | | 0 | | | | | | T | | | $\bigcirc$ | | | | | | 0 | 0 | | | | ^ | ^ | #### **IMPLEMENTATION: 4-BIT MAGNITUDE COMPARATOR** Fixed-Function Device The 74HC85/74LS85 pin diagram and logic symbol are shown in Figure 6–23. Notice that this device has all the inputs and outputs of the generalized comparator previously discussed and, in addition, has three cascading inputs: A < B, A = B, A > B. These inputs allow several comparators to be cascaded for comparison of any number of bits greater than four. To expand the comparator, the A < B, A = B, and A > B outputs of the lower-order comparator are connected to the corresponding cascading inputs of the next higher-order comparator. The lowest-order comparator must have a HIGH on the A = B input and LOWs on the A < B and A > B inputs. FIGURE 6–23 The 74HC85/74LS85 4-bit magnitude comparator. #### **EXAMPLE 6-7** Use 74HC85 comparators to compare the magnitudes of two 8-bit numbers. Show the comparators with proper interconnections. #### **Solution** Two 74HC85s are required to compare two 8-bit numbers. They are connected as shown in Figure 6–25 in a cascaded arrangement. FIGURE 6-25 An 8-bit magnitude comparator using two 74HC85s. Decoding functions and truth table for a \(\pmu\)-line-to-16-line (1-of-16) decoder with active-LOW outputs. | Decimal | Binary Inputs | | Decoding | V | | <b>-</b> / | | | | | Out | puts | | | | | | | | | | |---------|---------------|-------|----------|-------|------------------------------------------------------------|------------|---|----|---|---|-----|------|---|---|---|----|----|----|----|----|----| | Digit | $A_3$ | $A_2$ | $A_1$ | $A_0$ | Function | 10 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | 0 | 0 | 0 | 0 | 0 | $\overline{A}_3\overline{A}_2\overline{A}_1\overline{A}_0$ | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | 1 | 0 | 0 | 0 | 1 | $\overline{A}_3\overline{A}_2\overline{A}_1A_0$ | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | 2 | 0 | 0 | 1 | 0 | $\overline{A}_3\overline{A}_2A_1\overline{A}_0$ | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | 3 | 0 | 0 | 1 | 1 | $\overline{A}_3\overline{A}_2A_1A_0$ | 1 | 1 | 1 | Q | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | 4 | 0 | 1 | 0 | 0 | $\overline{A}_3 A_2 \overline{A}_1 \overline{A}_0$ | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | 5 | 0 | 1 | 0 | 1 | $\overline{A}_3 A_2 \overline{A}_1 A_0$ | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | 6 | 0 | _1_ | 1 | 0 | $\overline{A}_3 A_2 A_1 \overline{A}_0$ | 1 | 1 | 1 | 1 | 1 | 1 | Q | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | 7 | (0 | _1_ | | | $\overline{A}_3 A_2 A_1 A_0$ | 1 | 1 | 1 | 1 | 1 | 1 | 1 | P | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | 8 | 1 | 0 | 0 | 0 | $A_3\overline{A}_2\overline{A}_1\overline{A}_0$ | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | 9 | 1 | 0 | 0 | 1 | $A_3\overline{A}_2\overline{A}_1A_0$ | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | | 10 | 1 | 0 | 1 | 0 | $A_3\overline{A}_2A_1\overline{A}_0$ | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | | 11 | 1 | 0 | 1 | 1 | $A_3\overline{A}_2A_1A_0$ | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | | 12 | 1 | 1 | 0 | 0 | $A_3A_2\overline{A}_1\overline{A}_0$ | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | | 13 | 1 | 1 | 0 | 1 | $A_3A_2\overline{A}_1A_0$ | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | | 14 | 1 | 1 | 1 | 0 | $A_3A_2A_1\overline{A}_0$ | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | | 15 | 1 | 1_ | 1 | 1 | 434241A0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | | 0 | ) | 7 | 13 F | le F | 1 Ao. | = | | M. | | | | | Ä | = | γ | NA | - | | | | | #### **IMPLEMENTATION: 1-OF-16 DECODER** Fixed-Function Device The 74HC154 is a good example of a fixed-function IC decoder. The logic symbol is shown in Figure 6–29. There is an enable function (EN) provided on this device, which is implemented with a NOR gate used as a negative-AND. A LOW level on each chip select input, $\overline{CS}_1$ and $\overline{CS}_2$ , is required in order to make the enable gate output (EN) HIGH. The enable gate output is connected to an input of each NAND gate in the decoder, so it must be HIGH for the NAND gates to be enabled. If the enable gate is not activated by a LOW on both inputs, then all sixteen decoder outputs (OUT) will be HIGH regardless of the states of the four input variables, $A_0$ , $A_1$ , $A_2$ , and $A_3$ . FIGURE 6-29 The 74HC154 1-of-16 decoder. 7425138- Y1 Y2 Y4 Y7 $C_0 = M_3 + M_5 + M_6 + M_7$ = T3+ K5+ K6+K7 - Y3 Y5 Y6 Y7 FIGURE 6–30 A 5-bit decoder using 74HC154s. # **Design voting machine via 74HC154** ### The BCD-to-Decimal Decoder ### TABLE 6-5 BCD decoding functions. | Decimal | | Decoding | | | | |---------|-------|----------|-------|-------|------------------------------------------------------------| | Digit | $A_3$ | $A_2$ | $A_1$ | $A_0$ | Function | | 0 | 0 | 0 | 0 | 0 | $\overline{A}_3\overline{A}_2\overline{A}_1\overline{A}_0$ | | 1 | 0 | 0 | 0 | 1 | $\overline{A}_3\overline{A}_2\overline{A}_1A_0$ | | 2 | 0 | 0 | 1 | 0 | $\overline{A}_3\overline{A}_2A_1\overline{A}_0$ | | 3 | 0 | 0 | 1 | 1 | $\overline{A}_3\overline{A}_2A_1A_0$ | | 4 | 0 | 1 | 0 | 0 | $\overline{A}_3 A_2 \overline{A}_1 \overline{A}_0$ | | 5 | 0 | 1 | 0 | 1 | $\overline{A}_3 A_2 \overline{A}_1 A_0$ | | 6 | 0 | 1 | 1 | 0 | $\overline{A}_3 A_2 A_1 \overline{A}_0$ | | 7 | 0 | 1 | 1 | 1 | $\overline{A}_3 A_2 A_1 A_0$ | | 8 | 1 | 0 | 0 | 0 | $A_3\overline{A}_2\overline{A}_1\overline{A}_0$ | | 9 | 1 | 0 | 0 | 1 | $A_3\overline{A}_2\overline{A}_1A_0$ | #### **IMPLEMENTATION: BCD-TO-DECIMAL DECODER** **Fixed-Function Device** The 74HC42 is a fixed-function IC decoder with four BCD inputs and ten active-LOW decimal outputs. The logic symbol is shown in Figure 6–31. FIGURE 6-31 The 74HC42 BCD-to-decimal decoder. ### The BCD-to-7-Segment Decoder #### IMPLEMENTATION: BCD-TO-7-SEGMENT DECODER/DRIVER Fixed-Function Device The 74HC47 is an example of an IC device that decodes a BCD input and drives a 7-segment display. In addition to its decoding and segment drive capability, the 74HC47 has several additional features as indicated by the $\overline{LT}$ , $\overline{RBI}$ , $\overline{BI}/\overline{RBO}$ functions in the logic symbol of Figure 6–34. As indicated by the bubbles on the logic symbol, all of the outputs (a through g) are active-LOW as are the $\overline{LT}$ (lamp test), $\overline{RBI}$ (ripple blanking input), and $\overline{BI}/\overline{RBO}$ (blanking input/ripple blanking output) functions. The outputs can drive a common-anode 7-segment display directly. Recall that 7-segment displays were discussed in Chapter 4. In addition to decoding a BCD input and producing the appropriate 7-segment outputs, the 74HC47 has lamp test and zero suppression capability. FIGURE 6-34 The 74HC47 BCD-to-7-segment decoder/driver. ### **Encoders** The Decimal-to-BCD Encoder | | | | | | | _ | |-----------------------------------------|------------------------|-----------------|-------|-------|-------|-------------| | | TABLE 6-6 | | | | | \ <u></u> | | | $\overline{}$ | | /73 | | | | | | <b>Decimal Digit</b> 9 | $\widehat{A_3}$ | $A_2$ | $A_1$ | $A_0$ | | | | 0 | 0 | 0 | 0 | 0 | 7 7 7 7 | | | 1 | 0 | 0 | 0 | 1 | 70 71 78 74 | | | 2 | 0 | 0 | 1 | 0 | ~ | | | 3 | 0 | 0 | 1 | 1 | て ・・・・・ デ | | | 4 | 0 | 1 | 0 | 0 | 20 28 19 | | | <del>-</del> 5 ~ | 0 | 1 | 0 | 1 | | | | ) 8 6 Ja | 0 | 1 | 1 | 0 | | | 1 | 7 | 0 | 1 | 1 | 1 | | | C ~ · · · · · · · · · · · · · · · · · · | 10 & | 1 | 0 | 0 | 0 | | | \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ | · ~ ~ 9 0 | 1 | 0 | 0 | 1 | _ | ### **IMPLEMENTATION: DECIMAL-TO-BCD ENCODER** **Fixed-Function Device** The 74HC147 is a priority encoder with active-LOW inputs (0) for decimal digits 1 through 9 and active-LOW BCD outputs as indicated in the logic symbol in Figure 6–38. A BCD zero output is represented when none of the inputs is active. The device pin numbers are in parentheses. **FIGURE 6–38** The 74HC147 decimal-to-BCD encoder (HPRI means highest value input has priority. FIGURE 6-39 A simplified keyboard encoder. # **Multiplexers (Data Selectors)** #### **TABLE 6-8** Data selection for a 1-of-4-multiplexer. | I | Data-S | elect Inputs | Υ | |---|--------|--------------|----------------| | | $S_1$ | $S_0$ | Input Selected | | | 0 | 0 | $D_0$ | | | 0 | 1 | $D_1$ | | | 1 | 0 | $D_2$ | | | 1 | 1 | $D_3$ | **FIGURE 6-44** Logic diagram for a 4-input multiplexer. Open file F06-44 to verify operation. $$\begin{array}{c|c} ABC & + ABC & + ABC \\ -ABC & + ABC & + ABC \\ -ABC & + ABC & + ABC \\ -ABC & + ABC & + ABC & + ABC \\ -ABC & + ABC & + ABC & + ABC \\ -ABC & + ABC & + ABC & + ABC \\ -ABC & + ABC & + ABC & + ABC \\ -ABC & + ABC & + ABC & + ABC \\ -ABC & + ABC & + ABC & + ABC \\ -ABC & + ABC & + ABC & + ABC & + ABC \\ -ABC & + ABC & + ABC & + ABC & + ABC & + ABC \\ -ABC & + ABC &$$ $$Vac Ci = S_{2}$$ $$S_{1}$$ $$S_{2}$$ $$S_{3}$$ $$S_{4}$$ $$S_{5}$$ $$S_{5}$$ $$S_{7}$$ $$S_{1}$$ $$S_{8}$$ $$S_{1}$$ $$S_{8}$$ $$S_{1}$$ $$S_{8}$$ $$S_{1}$$ $$S_{1}$$ $$S_{1}$$ $$S_{2}$$ $$S_{1}$$ $$S_{2}$$ $$S_{1}$$ $$S_{2}$$ $$S_{1}$$ $$S_{2}$$ $$S_{1}$$ $$S_{2}$$ $$S_{1}$$ $$S_{2}$$ $$S_{3}$$ $$S_{4}$$ $$S_{1}$$ $$S_{1}$$ $$S_{2}$$ $$S_{3}$$ $$S_{4}$$ $$S_{1}$$ $$S_{1}$$ $$S_{2}$$ $$S_{3}$$ $$S_{4}$$ $$S_{1}$$ $$S_{1}$$ $$S_{2}$$ $$S_{3}$$ $$S_{4}$$ $$S_{1}$$ $$S_{1}$$ $$S_{2}$$ $$S_{3}$$ $$S_{4}$$ $$S_{1}$$ $$S_{1}$$ $$S_{2}$$ $$S_{3}$$ $$S_{4}$$ $$S_{4}$$ $$S_{5}$$ $$S_{1}$$ $$S_{1}$$ $$S_{2}$$ $$S_{3}$$ $$S_{4}$$ $$S_{5}$$ $$S_{1}$$ $$S_{4}$$ $$S_{5}$$ $$S_{5}$$ $$S_{6}$$ $$S_{7}$$ $$S_{1}$$ $$S_{7}$$ $$S_{$$ #### IMPLEMENTATION: DATA SELECTOR/MULTIPLEXER Fixed-Function Device The 74HC153 is a dual four-input data selector/multiplexer. The pin diagram is shown in Figure 6–46(a). The inputs to one of the multiplexers are 110 through 113 and the inputs to the second multiplexer are 210 through 213. The data select inputs are S0 and S1 and the active-LOW enable inputs are 1E and 2E. Each of the multiplexers has an active-LOW enable input. The ANSI/IEEE logic symbol with dependency notation is shown in Figure 6–46(b). The two multiplexers are indicated by the partitioned outline, and the inputs common to both multiplexers are inputs to the notched block (common control block) at the top. The $G_3^0$ dependency notation indicates an AND relationship between the two select inputs (A and B) and the inputs to each multiplexer block. **FIGURE 6-46** The 74HC153 dual four-input data selector/multiplexer. FIGURE 6-48 A 16-input multiplexer. ### Use Slector to design a voting machine **FIGURE 6–50** Data selector/multiplexer connected as a 3-variable logic function generator. # **Demultiplexers** FIGURE 6-52 A 1-line-to-4-line demultiplexer. (3-3 ) 海崎縣. 8-1 海塘塘港. 1-8 海塘分形器. (NAND)