

Design #2



Part (1)

- (1) Create a truth table
- (2) Build the K-map
- (3) Find the switching function SOP for  $y$
- (4) Write the Verilog for your design  
& test the syntax



Use the design in part (1) to  
build a 4bit 2-to-1 MUX

Four\_bit\_2to1\_MUX

# Truth Table for Single\_bit\_Mux :

| A | B | Sel | Y |
|---|---|-----|---|
| 0 | 0 | 0   | 0 |
| 0 | 0 | 1   | 0 |
| 0 | 1 | 0   | 0 |
| 0 | 1 | 1   | 1 |
| 1 | 0 | 0   | 1 |
| 1 | 0 | 1   | 0 |
| 1 | 1 | 0   | 1 |
| 1 | 1 | 1   | 1 |

$A\bar{Sel}$   
 $+ B Sel$

K-map



Part II





| Sel | $y$ |
|-----|-----|
| 00  | A   |
| 01  | B   |
| 10  | C   |
| 11  | D   |

Truth table  
for the 4 to 1 Mux

## // Testbench module

module

Four\_bit\_2to1\_MUX\_TB

name of your  
module to be tested

TB for test bench

reg [3:0] fourBit\_A\_in ;

reg [3:0] fourBit\_B\_in ;

reg Sel\_in ;

wire [3:0] fourBit\_Y\_out ;

original  
inputs of  
the UUT

original output  
of the UUT

notice that the test  
bench module does  
not have any ports.  
(Simulation)

Four\_bit\_2to1\_MUX

UUT

(fourBit\_Y\_out, fourBit\_A\_in,  
fourBit\_B\_in, Sel\_in) ;

instantiation of the  
module under test

Instance name  
Unit Under Test



initial

begin

Time units

#10

four Bit\_A\_in = 4'b0000 ;

four Bit\_B\_in = 4'b1111 ;

sel\_in = 1 ;

sel\_in = 0 ;

#10

four Bit\_A\_in = 4'b0001 ;

#10

four Bit\_A\_in = 4'b0010 ;

#10

four Bit\_A\_in = 4'b1100 ;

:

end

End module



example  
initial  
block

initial

begin

~~##~~ 100  
~~##~~ 100

fourBit\_A\_in = 4'b0000;

fourBit\_A\_in = 4'b0001;

fourBit\_A\_in = 4'b0010;

:

end

example  
always  
block

always begin

~~##~~ 100

fourBit\_A\_in = fourBit\_A\_in + 1;

end

all blocks run in parallel