

Project 2  
System Synthesis and Modeling

Zack Fravel

010646947

[zpfravel@uark.edu](mailto:zpfravel@uark.edu)

## Objective

The parent objective of Project 2 was to design a 7:1 multiplexer, that is seven inputs to one output, as well as get more familiar with the ModelSim tools and the design flow. After we design the mux we're also tasked to create a suitable testbench and analyze the simulation to verify our mux design.

## Design and Simulation

The idea of the multiplexer is fairly straight forward, we'll have multiple inputs and one output with additional selector inputs that route the desired input to the output. Below is the circuit diagram showing the idea.

Mux Diagram



Figure 1

Basically you'll have seven inputs, and one output. In order to distinguish between all seven inputs we need three selector bits, which technically could account for up to eight inputs.

However, that just means we have a don't-care case and we'll just output the last input for both "110" and "111."

I have also attached the source verilog files to the end of this report showing how it is implemented in the ModelSim tools. Basically, all that is needed is to declare the necessary ports, and create an always@ block that is sensitive to all the inputs to the mux, especially the selectors. In this always@ block you have a case statement for sel2, sel1, sel0 in that order. Then below that you're able to set the declarations for each output (using the format 3'b000 to represent sel2=0, sel1=0, sel0=0). Once you've accounted for all the cases and assigned the respective inputs to the output at each case (using non-blocking assignment).

Finally, we need a way to test our design. I went with writing a testbench as my method of simulation. In my testbench I declare all the inputs and outputs as registers and instantiate the module I designed using the format [Project2 test (in0, in1, ... sel2);]. After that, I created an initial block and after the begin statement I assign each of the seven outputs to a different 8 bit number (seven powers of 2). At the top of my testbench I use the compiler directive `timescale 1ns/1ns so that I can use #20 to spread my test cases 20 ns apart. Then below my initial input assignments I test each selector case 20 ns at at time.

### **Results, Analysis, and Conclusion**

Once I got both the testbench and module files compiling I was able to start simulating. In the simulation I set the radix of the output to decimal so it's more obvious to see on the screenshot when the output changes what it's value is changing to. The testbench initializes all the inputs, waits 40 ns and then starts going through each selector case 20 ns at at time. The resulting output can be observed on the bottom line.

Simulation Waveform



Figure 2

It can be seen above that the testbench goes through all eight combinations of selector bits within the 200 ns that is shown in the screenshot. Each time the selector changes the output also changes to its respective input. Again, as stated earlier, the seventh input gets asserted to the output for both the 110 and 111 cases, since we only have seven inputs for eight cases.

With all that laid out, we should have all we need taken care of for Project 2. To reiterate, we successfully designed a 7:1 multiplexer with an associated testbench that tests all possible cases and showed its functionality with the waveform simulation. All source files mentioned are included.

### Project2.v

```
1 // Zack Fravel
2 // System Synthesis and Modeling
3 // Project2.v
4
5 `timescale 1ns / 1ns
6 module Project2 (
7 // Port Declarations
8     input[7:0] i0, i1, i2, i3, i4, i5, i6,
9     output reg[7:0] o,
10    input sel0, sel1, sel2
11 );
12
13 // 7:1 Mux
14 always @(i0 or i1 or i2 or i3 or i4 or i5 or i6 or
15           sel0 or sel1 or sel2)
16 begin
17     case ({sel2, sel1, sel0})
18         3'b000: o <= i0;
19         3'b001: o <= i1;
20         3'b010: o <= i2;
21         3'b011: o <= i3;
22         3'b100: o <= i4;
23         3'b101: o <= i5;
24         3'b110: o <= i6;
25         3'b111: o <= i6;
26     endcase
27 end
28
29 endmodule
```

### Project2\_tb.v

---

```
1 // Zack Fravel
2 // System Synthesis and Modeling
3 // Project2_tb.v
4
5 `timescale 1ns / 1ns
6 module Project2_tb;
7 // Declarations
8
9 // Inputs
10 reg[7:0] in0, in1, in2, in3, in4, in5, in6;
11
12 // Select input bits
13 reg sel0, sel1, sel2;
14
15 // Output Wire
16 wire[7:0] out;
17
18 // Instantiate 7:1 mux
19 Project2 test(in0, in1, in2, in3, in4, in5, in6, out, sel0, sel1, sel2);
20
21 // Testbench
22
23 // Set Inputs
24
25 initial // Test stimulus
26 begin
27     in0 = 8'b00000001;
28     in1 = 8'b00000010;
29     in2 = 8'b00000100;
30     in3 = 8'b00001000;
31     in4 = 8'b00010000;
32     in5 = 8'b00100000;
33     in6 = 8'b01000000;
34
35 #20 // wait before testing
36
37 #20 sel2 = 0; sel1 = 0; sel0 = 0; // 000
38 #20 sel2 = 0; sel1 = 0; sel0 = 1; // 001
39 #20 sel2 = 0; sel1 = 1; sel0 = 0; // 010
40 #20 sel2 = 0; sel1 = 1; sel0 = 1; // 011
41 #20 sel2 = 1; sel1 = 0; sel0 = 0; // 100
42 #20 sel2 = 1; sel1 = 0; sel0 = 1; // 101
43 #20 sel2 = 1; sel1 = 1; sel0 = 0; // 110
44 #20 sel2 = 1; sel1 = 1; sel0 = 1; // 111
45
46 end
47
48 endmodule
```