Problems Chapter3
Problems Chapter3
Problems Chapter3
to the truth table to describe the next state. So the columns are organizes as inputs : state : next state.
In this section, we introduced the Verilog HDL and presented simple examples to illustrate alternatives for modeling combinational logic. A more detailed presentation of Verilog HDL can be found in the next chapter. The reader familiar with combinational circuits can go directly to Section 4.12 to continue with this subject.
Answers to problems marked with " appear at the end of the book.
Simplify the following Boolean functions, using three-variable maps:
(a) F(x,y,z) 2:(0,2,6,7) (b) F(x,y,z) = 2:(0,2,3,4,6)
(c) F(x, y, z) = 2:(0,1,2,3,7) (d) F(x, y, z) = 2:(3,5,6,7)
Simplify the following Boolean functions, using three-variable maps:
(a)" F(x, y, z) = 2:(0,1,5,7) (b)" F(x, y, z) = 2:(1,2,3,6,7)
(c) F(x, y, z) = 2:(0,1,6,7) (d) F(x, y, z) = 2:(0,1,3,4,5)
(e) F(x,y,z) 2:(1,3,5,7) (f) F(x,y,z) = 2:(1,4,5,6,7)
Simplify the following Boolean expressions, using three-variable maps:
(at F(x,y,z) xy + x'y'z' + x'vz' (b)" F(x,y,z) = x'y' + yz + x'yz'
(c)' F(x, y, z) x'y + yz' + y'z' (d) F(x, y, z) = xyz + x'y'z + xy'z'
Simplify the following Boolean functions, using Karnaugh maps:
(a) F(x, y, z) 2:(2,3,6,7) (bY' F(A, B, C, D) 2:(4,6,7,15)
(c) F(A, B, C, D) = 2:(3,7,11,13,14,15) (d)" F(w, x, y, z) 2:(2,3,12,13,14,15)
(e) F(w, x, y, z) 2:(1,4,5,6,7,13) (f) F(w, x, y, z) = 2:(0,1,5,8,9)
Simplify the following Boolean functions, using four-variable maps:
(a)" F(w, x, y, z) = 2:(1,4,5,6,12,14,15)
(b) F(A, B, C, D) = 2:(1,5,9,10,11,14,15)
(c) F(w, x, y, z) 2:(0,1,4,5,6,7,8,9)
(d)' F(A, B, C, D) = 2:(0,2,4,5,6,7,8,10,13,15)
Simplify the following Boolean expressions, using four-variable maps: (a) A'B'C'D' + AC'D' + B'CD' + A'BCD + BC'D
(by x'z + w'xy' + w(x'y + xy')
(c) A'B'C'D' + A'CD' + AB'D' + ABCD + A'BD (d) A'B'C'D' + AB'C + B'CD' + ABCD' + BC'D
Simplify the following Boolean expressions, using four-variable maps: (a)" w'z + xz + x'y + wx'z
(b) C'D + A' B'C + ABC' + AB'C
(c)' AB'C + B'C'D' + BCD + ACD' + A'B'C + A'BC'D (d) xyz + wy + wxy' + x'y
Find the minterms of the following Boolean expressions by first plotting each function in a map:
(a) xy + yz + xy'z (b)" C'D + ABC' + ABD' + A'B'D
(c) wyz + w'x' + wxz' (d) A'B + A'CD + B'CD + BC'D'
Find all the prime implicants for the following Boolean functions, and determine which are essential:
(a)" F(w, x, y, z) = 2:(0,2,4,5,6,7,8,10,13,15) (b)''F(A, B, C, D) = 2:(0,2,3.5,7,8, 10, 11, 14, 15) (c) F(A, B, C, D) = 2:(1,3,4,5,10,11,12,13,14,15) (d) F(w, x, y, z) = 2:(1,3,6,7,8,9,12,13,14,15)
(e) F(A, B, C, D) = 2:(0,2,3,5,7,8,10,11,13,15) (D F(w,x,y,z) = 2:(0,2,7,8,9,10,12,13,14,15)
Simplify the following Boolean functions by first finding the essential (a) F(w, x, y, z) = 2:(0,2,4,5,6,7,8,10,13,15)
(b) F(A, B, C, D) = 2:(0,2,3,5,7,8, 10, 11, 14, 15)
(c)" F(A, B, C, D) = 2:(1,3,4,5,10,11,12,13,14,15)
(d) F(w, x, y, z) = 2:(1,3,6,7,8,9,12,13,14,15)
(e) F(A, B, C, D) = 2:(0,2,3,5,7,8,10,11,13,15)
CD F(w,x,y,z) = 2:(0,2,7,8,9,10,12,13,14,15)
implicants:
Simplify the following Boolean functions, using five-variable maps: (a)* F(A, B, C, D, E) = 2:(0,1,4,5,16,17,21,25,29)
(b) F(A,B,C,D) = A'B'CE' + B'C'D'E' + A'B'D' + B'CD' + A'CD + A'BD
Simplify the following Boolean functions to product-of-sums form:
(a) F(w, x, y, z) = 2:(0,1,2,5,8,10,13)
(b)*F(A, B, C, D) = n (1, 3, 5, 7,13,15)
(c) F(A, B, C, D) = I1 (1, 3, 6, 9,11,12,14)
Simplify the following expressions to (1) sum-of-products and (2) products-of-sums: (at x'z' + y'z' + yz' + xy
(b) ACD' + C'D + AB' + ABCD
(c) (A + C' + D')(A' + B' + D')(A' + B + D')(A' + B + C') (d) ABC' + AB'D + BCD
Give three possible ways to express the following Boolean function with eight or fewer literals:
F = B'C'D' + AB'CD' + BC'D + A'BCD
Simplify the following Boolean function F, together with the don't-care conditions d, and then express the simplified function in sum-of-minterms form:
(a) F(x, y, z) = 2:(2,3,4,6,7) (bY' F(A, B, C, D)
d(x,y,z) = 2:(0,1,5) d(A,B,C,D)
(c) F(A, B, c, D) = 2:(4,5,7,12,13,14) Cd) F(A, B, C, D)
dCA, B, C, D) = 2:(1,9,11,15) dCA, B, C, D)
2:(0,6,8,13,14) 2:(2,4,10) 2:(1,3,8,10,15) 2:(0,2,9)
Simplify the following functions, and implement them with two-level NAND gate circuits:
(a) B, C, D) = A' B'C + AC' + ACD + ACD' + A' B' D'
(b) F(A,B,C,D) = AB + A'BC + A'B'C'D
(c) F(A, B, C) = (A' + B' + C')(A' + B')(A' + C') (d) F(A, B, C, D) = A' B + A + C' + D'
Draw a NAND logic diagram that implements the complement of the following function:
F(A, B, C, D) = 2:(0,1,2,3,4,8,9,12)
8
3 Gate-level
Draw a logic
only
F(A,B,C,D) = (AEljB)' (C Elj D)
Simplify the following functions, and implement them with two-level NOR gate circuits:
Cal" F = wx' + + w'yz '
x,y,z) 2:(1,2,13,14)
(c) F(x, y, z) + y)(x' + z)]'
Draw the multi-level NOR and multi-level NAND circuits for the
expression:
(AB' + CD')E + BC(A + B)
Draw the multi-level NAND circuit for L'1e following expression: w(x + y + z) + xyz
Convert the logic diagram of the circuit shown in Fig. 4.4 into a NAND circuit.
HHfJ''-,lH'-''CH the Boolean function F, together with the don't-care conditions d, using no
more than two NOR gates:
F(A, B, C, D) = 2:(2,4,6,10,12) dCA, B, C, D) = 2:(0,8,9,13)
Assume that both the normal and complement inputs are available.
UHfJ"."n,u, the following Boolean function F, using the two-level forms of logic (a) NANDAND-NOR, (c) OR-NAND, and (d) NOR-OR:
F(A, B, C, D) = 2:(0,4,8,9,10,11,12,14)
List the degenerate two-level forms and show that they reduce to a operation. Explain
how the degenerate two-level forms can be used to extend the number of inputs to a gate.
With the use of maps, find the simplest sum-of-products form of the function F = f g, where
f = abc' + c'd + a'cd' + b'cd'
and
g (a + b + c' + d')(b' + c' + d)(a' + c + d')
Show that the dual of the exclusive-OR is also its complement. Derive the circuits for a three-bit parity generator and four-bit parity bit.
checker using an odd
D=AEljBEljC
E = A'BC + AB'C
F = ABC' + (A' + B')C G = ABC
UHlHlOlUvJlll the following Boolean expression with exclusive-OR and AND gates:
F AB'CD' + A'BCD' + AB'C'D + A'BC'D
Write a Verilog gate-level description of the circuit shown in
(a) Fig.3.22(a) (b) Fig.3.22(b) (c) Fig.3.23(a)
(d) Fig.3.23(b) (e) 3.26 (f) Fig. 3.27
Using continuous assignment statements, write a Verilog description of the circuit shown in
(a) Fig.3.22(a) (b) Fig.3.22(b) (c) Fig.3.23(a)
(d) Fig.3.23(b) (e) 3.26 (f) Fig. 3.27
The exclusive-OR circuit of 3.32(a) has gates with a delay of 4 ns for an inverter, a 8 ns delay for an AND gate, and a IOns delay for an OR gate. The input of the circuit goes from
xy = 00 to xy 01.
(a) Determine the signals at the output of each gate from t = 0 to t = 50 ns. (b) Write a Verilog gate-level description of the circuit, including the delays.
(c) Write a stimulus module (i.e., a test bench similar to HDLExampJe 3.3), and simulate the circuit to verify the answer in part (a).
Using continuous assignments, write a Verilog description of the circuit specified by the following Boolean functions:
Out 1 = (C + B) (A' + D)B'
Out 2 (CB' + ABC + C'B)(A + D')
Out 3 = C(AD + B) + BA'
Write a test bench and simulate the circuit's behavior.
Find the syntax errors in the following declarations (note that names for primitive gates are optional):
module Exmpl-3(A, B, C, 0, F) II Line 1
inputs A, B, C, Output 0, F, II Line 2
output B II Line 3
and g1(A, B, D); II Line 4
not (0, A, C), II Line 5
OR B; C); II Line 6
endofmodule: II Line 7 Draw the logic diagram of the digital circuit specified by the following Verilog description:
(a) module Circuit_A (A, B, C, 0, F);
input A, B,C, 0;
output F'
,
wire w, x, y, z, a, d;
and (x, B, C, d);
and (y, a ,C);
and (w, z
or y, A);
or x, w);
not (a, A);
not (d, D);
endrnodule (b) module Circuit_B (A_gtB, A_ltB, A_eqB, AD, Ai, BO, B1); output A_gtB, A_ltB, A_eqB;
input AD, Ai, BO, B1;
nor (A_gtB, A_ltB, A_eqB);
or (A_ltB, wt, w2, w3);
and (A_eqB, w4, w5);
and (wt, w6, B1);
and (w2, w6, w7, BO);
and (w3, w7, BO, B1);
not (w6, A 1 );
not (w7, AD);
xnor (w4, At, B1);
xnor (w5, AD, BO);
endmodule
(c) module Circuit_C (output y1, input a, b, output y2); assign y1 = a & b;
or (y2, a, b);
endmodule
A majority logic function is a Boolean function that is equal to 1 if the majority of the variables are equal to 1, equal to 0 otherwise. Write a Verilog user-defined primitive for a four-bit majority function.
Simulate the behavior of Circuit_with_UDP _02467, using the stimulus waveforms shown in Fig. P3.38.
A
t, ns
B
t, ns
10 20 30 40 50 60 70 80
C
t, ns
10 20 30 40 50 60 70 80