## **LAB1 - 2 to 1 Mux**

## **Group A:**

- Jihun Choi(Bronco ID#: 011841206)
- Jacky Li(Bronco ID#:014181245)

## **Prof.Aly**

## ECE3300L.02 - Summer 2022

This lab1 is about designing a 2 to1 multiplexer by using vivado software and test the results with FPGA. 2 input 'a' and 'b' will each be 4 bits, 'sel' which is select line will be just 1 bit. Output 'f' will be also 4 bits. The function of 2 to 1 multiplexer is pretty simple. If selected line 'sel' equals 0, output 'f' will be same as input 'a'. Else, if the selected line 'sel' equals 0, output 'f' will be the same as input 'b'.



To make input 'a' and 'b' 4bits, '[3:0]' was used. Same for output 'f', [3:0] was used. Once ports are set correctly, always block was used to implement if else statement.

After setting up the source file, test bench was created to test, if 2 to1 multiplexer designed functions as it intended.

```
initial
module mux2to1_tb(
                                                                     begin
                                                                              a_in =4'b<mark>0101</mark>;
                                                                              b_in =4'b1001;
                   );
                                                                             sel_in = 0;
                                                                              #20
                   reg [3:0] a_in;
                                                                              a_in =4'b<mark>0101</mark>;
                                                                              b_in =4'b1001;
                   reg [3:0] b_in;
                                                                              sel_in = 1;
                   reg sellin:
                                                                              #20
                                                                              a_in =4'b0001:
                   wire [3:0] led:
                                                                              b_in =4'b0011:
                                                                              sel_in = O:
                                                                              #20
                   mux2to1 M (
                            .a(a_in),
                                                                              a_in =4'b0001;
                                                                              b_in =4'b0011:
                            .b(b_in),
                                                                              sel_in = 1;
                            .sel(sel_in),
                                                                              #20
                            .f(led)
                                                                              $finish:
                                 );
                                                                         end
                                                        endmodule
```



After checking simulation results, 2 to 1 multiplexer is functioning correctly. xdc file was modified to properly work and the result was tested on FPGA.

Video link:

https://drive.google.com/file/d/1x5HYhGleaSPITdKOiEAVvxS3RKGg-sDl/view?usp=sharing

or

https://youtube.com/shorts/45CRVI5ur-A?feature=share

