

# Numericals Chapter 4

- 4-1. Show the block diagram of the hardware (similar to Fig. 4-2a) that implements the following register transfer statement:

$$yT_2: R2 \leftarrow R1, \quad R1 \leftarrow R2$$

Figure 4-2 Transfer from  $R1$  to  $R2$  when  $P = 1$ .



**4.1**



- 4-2. The outputs of four registers,  $R_0$ ,  $R_1$ ,  $R_2$ , and  $R_3$ , are connected through 4-to-1-line multiplexers to the inputs of a fifth register,  $R_5$ . Each register is eight bits long. The required transfers are dictated by four timing variables  $T_0$  through  $T_3$  as follows:

$$T_0: R_5 \leftarrow R_0$$

$$T_1: R_5 \leftarrow R_1$$

$$T_2: R_5 \leftarrow R_2$$

$$T_3: R_5 \leftarrow R_3$$

The timing variables are mutually exclusive, which means that only one variable is equal to 1 at any given time, while the other three are equal to 0. Draw a block diagram showing the hardware implementation of the register transfers. Include the connections necessary from the four timing variables to the selection inputs of the multiplexers and to the load input of register  $R_5$ .

4.2



| $T_0 T_1 T_2 T_3$ | $S_1 S_0 R_3$ | load |
|-------------------|---------------|------|
| 0 0 0 0           | X X 0         |      |
| 1 0 0 0           | 0 0 1         |      |
| 0 1 0 0           | 0 1 1         |      |
| 0 0 1 0           | 1 0 1         |      |
| 0 0 0 1           | 1 1 1         |      |

$$S_1 = T_2 + T_3$$

$$S_0 = T_1 + T_3$$

$$\text{load} = T_0 + T_1 + T_2 + T_3$$

**4-3.** Represent the following conditional control statement by two register transfer statements with control functions.

If ( $P = 1$ ) then ( $R1 \leftarrow R2$ ) else if ( $Q = 1$ ) then ( $R1 \leftarrow R3$ )

**4.3**

P: R1  $\leftarrow$  R2

P'Q: R1  $\leftarrow$  R3

4-4.

What has to be done to the bus system of Fig. 4-3 to be able to transfer information from any register to any other register? Specifically, show the connections that must be included to provide a path from the outputs of register C to the inputs of register A.

Figure 4-3 Bus system for four registers.



## 4.4

Connect the 4-line common bus to the four inputs of each register.  
Provide a “load” control input in each register.  
Provide a clock input for each register.

To transfer from register C to register A:

Apply  $S_1S_0 = 10$  (to select C for the bus.)

Enable the load input of A

Apply a clock pulse.

4-5.

Draw a diagram of a bus system similar to the one shown in Fig. 4-3, but use three-state buffers and a decoder instead of the multiplexers.

Figure 4-3 Bus system for four registers.



4.5



- 4-6. A digital computer has a common bus system for 16 registers of 32 bits each. The bus is constructed with multiplexers.
- How many selection inputs are there in each multiplexer?
  - What size of multiplexers are needed?
  - How many multiplexers are there in the bus?

#### **4.6**

- (a) 4 selection lines to select one of 16 registers.
- (b)  $16 \times 1$  multiplexers.
- (c) 32 multiplexers, one for each bit of the registers.

- 4-7. The following transfer statements specify a memory. Explain the memory operation in each case.
- a.  $R2 \leftarrow M[AR]$
  - b.  $M[AR] \leftarrow R3$
  - c.  $R5 \leftarrow M[R5]$

**4.7**

- (a) Read memory word specified by the address in AR into register R2.
- (b) Write content of register R3 into the memory word specified by the address in AR.
- (c) Read memory word specified by the address in R5 and transfer content to R5  
(destroys previous value)

4-8.

Draw the block diagram for the hardware that implements the following statements:

$$x + yz: AR \leftarrow AR + BR$$

where  $AR$  and  $BR$  are two  $n$ -bit registers and  $x$ ,  $y$ , and  $z$  are control variables. Include the logic gates for the control function. (Remember that the symbol  $+$  designates an OR operation in a control or Boolean function but that it represents an arithmetic plus in a microoperation.)

**4.8**



**4-9.**

Show the hardware that implements the following statement. Include the logic gates for the control function and a block diagram for the binary counter with a count enable input.

$$xyT_0 + T_1 + y'T_2: AR \leftarrow AR + 1$$

**4.9**



- 4-10. Consider the following register transfer statements for two 4-bit registers  $R_1$  and  $R_2$ .

$$xT: \quad R_1 \leftarrow R_1 + R_2$$

$$x'T: \quad R_1 \leftarrow R_2$$

Every time that variable  $T = 1$ , either the content of  $R_2$  is added to the content of  $R_1$  if  $x = 1$ , or the content of  $R_2$  is transferred to  $R_1$  if  $x = 0$ . Draw a diagram showing the hardware implementation of the two statements. Use block diagrams for the two 4-bit registers, a 4-bit adder, and a quadruple 2-to-1-line multiplexer that selects the inputs to  $R_1$ . In the diagram, show how the control variables  $x$  and  $T$  select the inputs of the multiplexer and the load input of register  $R_1$ .

**4.10**



- 4-11. Using a 4-bit counter with parallel load as in Fig. 2-11 and a 4-bit adder as in Fig. 4-6, draw a block diagram that shows how to implement the following statements:

$x: R1 \leftarrow R1 + R2$       Add  $R2$  to  $R1$

$x'y: R1 \leftarrow R1 + 1$       Increment  $R1$

where  $R1$  is a counter with parallel load and  $R2$  is a 4-bit register.



Figure 4-6 4-bit binary adder.

**4.11**



- 4-12.** The adder-subtractor circuit of Fig. 4-7 has the following values for input mode  $M$  and data inputs  $A$  and  $B$ . In each case, determine the values of the outputs:  $S_3$ ,  $S_2$ ,  $S_1$ ,  $S_0$ , and  $C_4$ .

|    | $M$ | $A$  | $B$  |
|----|-----|------|------|
| a. | 0   | 0111 | 0110 |
| b. | 0   | 1000 | 1001 |
| c. | 1   | 1100 | 1000 |
| d. | 1   | 0101 | 1010 |
| e. | 1   | 0000 | 0001 |



Figure 4-7 4-bit adder-subtractor.

**4.12**

| M | A    | B      | Sum  | Cu |
|---|------|--------|------|----|
| 0 | 0111 | + 0110 | 1101 | 0  |
| 0 | 1000 | + 1001 | 0001 | 1  |
| 1 | 1100 | - 1000 | 0100 | 1  |
| 1 | 0101 | - 1010 | 1011 | 0  |
| 1 | 0000 | - 0001 | 1111 | 0  |

$$7 + 6 = 13$$

$$8 + 9 = 16 + 1$$

$$12 - 8 = 4$$

$$5 - 10 = -5 \text{ (in 2's comp.)}$$

$$0 - 1 = -1 \text{ (in 2's comp.)}$$

- 4-13. Design a 4-bit combinational circuit decrementer using four full-adder circuits.

$$4.13 \quad A - 1 = A + 2\text{'s complement of } 1 = A + 1111$$



- 4-14. Assume that the 4-bit arithmetic circuit of Fig. 4-9 is enclosed in one IC package. Show the connections among two such ICs to form an 8-bit arithmetic circuit.



Figure 4-9 4-bit arithmetic circuit.

**4.14**

*Cin*



Fig. 4-9



- 4-15. Design an arithmetic circuit with one selection variable  $S$  and two  $n$ -bit data inputs  $A$  and  $B$ . The circuit generates the following four arithmetic operations in conjunction with the input carry  $C_{in}$ . Draw the logic diagram for the first two stages.

| $S$ | $C_{in} = 0$            | $C_{in} = 1$                     |
|-----|-------------------------|----------------------------------|
| 0   | $D = A + B$ (add)       | $D = A + 1$ (increment)          |
| 1   | $D = A - 1$ (decrement) | $D = A + \bar{B} + 1$ (subtract) |

**4.15**

| S | Cin | X | Y         |           |
|---|-----|---|-----------|-----------|
| 0 | 0   | A | B         | $(A + B)$ |
| 0 | 1   | A | 0         | $(A + 1)$ |
| 1 | 0   | A | 1         | $(A - 1)$ |
| 1 | 1   | A | $\bar{B}$ | $(A - B)$ |



**4-16.** Derive a combinational circuit that selects and generates any of the 16 logic functions listed in Table 4-5.

TABLE 4-5 Truth Tables for 16 Functions of Two Variables

| $x$ | $y$ | $F_0$ | $F_1$ | $F_2$ | $F_3$ | $F_4$ | $F_5$ | $F_6$ | $F_7$ | $F_8$ | $F_9$ | $F_{10}$ | $F_{11}$ | $F_{12}$ | $F_{13}$ | $F_{14}$ | $F_{15}$ |
|-----|-----|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|----------|----------|----------|----------|----------|----------|
| 0   | 0   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 1     | 1     | 1        | 1        | 1        | 1        | 1        | 1        |
| 0   | 1   | 0     | 0     | 0     | 1     | 1     | 1     | 1     | 0     | 0     | 0     | 0        | 1        | 1        | 1        | 1        | 1        |
| 1   | 0   | 0     | 0     | 1     | 1     | 0     | 0     | 1     | 1     | 0     | 0     | 1        | 1        | 0        | 0        | 1        | 1        |
| 1   | 1   | 0     | 1     | 0     | 1     | 0     | 1     | 0     | 1     | 0     | 1     | 0        | 1        | 0        | 1        | 0        | 1        |

TABLE 4-6 Sixteen Logic Microoperations

| Boolean function      | Microoperation                        | Name           |
|-----------------------|---------------------------------------|----------------|
| $F_0 = 0$             | $F \leftarrow 0$                      | Clear          |
| $F_1 = xy$            | $F \leftarrow A \wedge B$             | AND            |
| $F_2 = xy'$           | $F \leftarrow A \wedge \bar{B}$       |                |
| $F_3 = x$             | $F \leftarrow A$                      | Transfer $A$   |
| $F_4 = x'y$           | $F \leftarrow \bar{A} \wedge B$       |                |
| $F_5 = y$             | $F \leftarrow B$                      | Transfer $B$   |
| $F_6 = x \oplus y$    | $F \leftarrow A \oplus B$             | Exclusive-OR   |
| $F_7 = x + y$         | $F \leftarrow A \vee B$               | OR             |
| $F_8 = (x + y)'$      | $F \leftarrow \bar{A} \vee \bar{B}$   | NOR            |
| $F_9 = (x \oplus y)'$ | $F \leftarrow \bar{A} \oplus \bar{B}$ | Exclusive-NOR  |
| $F_{10} = y'$         | $F \leftarrow \bar{B}$                | Complement $B$ |
| $F_{11} = x + y'$     | $F \leftarrow A \vee \bar{B}$         |                |
| $F_{12} = x'$         | $F \leftarrow \bar{A}$                | Complement $A$ |
| $F_{13} = x' + y$     | $F \leftarrow \bar{A} \vee B$         |                |
| $F_{14} = (xy)'$      | $F \leftarrow \bar{A} \wedge \bar{B}$ | NAND           |
| $F_{15} = 1$          | $F \leftarrow \text{all } 1's$        | Set to all 1's |

**4.16**



- 4-17.** Design a digital circuit that performs the four logic operations of exclusive-OR, exclusive-NOR, NOR, and NAND. Use two selection variables. Show the logic diagram of one typical stage.

**4.17**



- 4-18.** Register A holds the 8-bit binary 11011001. Determine the B operand and the logic microoperation to be performed in order to change the value in A to:
- a. 01101101
  - b. 11111101

**4.18**

(a)  $A = 11011001$   
 $B = \underline{10110100}$   $\oplus$   
 $A \leftarrow A \oplus B$  01101101

$$\begin{array}{r} A = 11011001 \\ B = \underline{11111101} \quad (\text{OR}) \\ \hline 11111101 \end{array} \qquad A \leftarrow AVB$$

4-19. The 8-bit registers  $AR$ ,  $BR$ ,  $CR$ , and  $DR$  initially have the following values:

$$\begin{aligned} AR &= 11110010 \\ BR &= 11111111 \\ CR &= 10111001 \\ DR &= 11101010 \end{aligned}$$

Determine the 8-bit values in each register after the execution of the following sequence of microoperations.

$$AR \leftarrow AR + BR$$

Add  $BR$  to  $AR$

$$CR \leftarrow CR \wedge DR, BR \leftarrow BR + 1$$

AND  $DR$  to  $CR$ , increment  $BR$

$$AR \leftarrow AR - CR$$

Subtract  $CR$  from  $AR$

4.19

(a)  $AR = 11110010$

$$BR = \underline{11111111} (+)$$

$$AR = 11110001$$

1010

(b)  $CR = 10111001$

$$\underline{DR = 11101010}^{(\text{AND})}$$

$$CR = 10101000$$

$$BR = 11111111 \quad CR = 10111001 \quad DR = 1110$$

$$BR = 1111 \ 1111$$

+1

$$\hline BR = 0000 \ 0000 \quad AR = 1111 \ 0001 \quad DR = 11101010$$

(c)  $AR = 11110001_{(-1)}$

$$\underline{CR = 10101000}$$

$$AR = 01001001; \quad BR = 00000000; \quad CR = 10101000;$$

$$DR = 11101010$$

- 4-20. An 8-bit register contains the binary value 10011100. What is the register value after an arithmetic shift right? Starting from the initial number 10011100, determine the register value after an arithmetic shift left, and state whether there is an overflow.

**4.20**

R = 10011100

Arithmetic shift right: 11001110

Arithmetic shift left: 00111000

overflow because a negative number changed to positive.

**4-21.** Starting from an initial value of  $R = 11011101$ , determine the sequence of binary values in  $R$  after a logical shift-left, followed by a circular shift-right, followed by a logical shift-right and a circular shift-left.

**4.21**

$$R = 11011101$$

Logical shift left:

10111010

Circular shift right:

01011101

Logical shift right:

00101110

Circular shift left:

01011100