## Majority Voter Simulation Results

## **Schematic**



Figure 1: Majority Voter Schematic

The figure above illustrates the majority voter schematic which takes in the three inputs (A, B, C) and outputs the majority value (Z). In other words, two of the three inputs were 0 and the third was 1, then the output would be a 0 and vice versa.

## **Verification Tests and Results**















Figure 2: Simulation Results for Verification

The figure above illustrates the simulation results for the verification process. As indicated in the figure above, the actual output matches the expected output for all cases. A truth table of the majority voter schematic and the port mapping is provided below.

| in1_tb | in2_tb | in3_tb | out1_tb | out1_expected |
|--------|--------|--------|---------|---------------|
| 0      | 0      | 0      | 0       | 0             |
| 0      | 0      | 1      | 0       | 0             |
| 0      | 1      | 0      | 0       | 0             |
| 0      | 1      | 1      | 1       | 1             |
| 1      | 0      | 0      | 0       | 0             |
| 1      | 0      | 1      | 1       | 1             |
| 1      | 1      | 0      | 1       | 1             |
| 1      | 1      | 1      | 1       | 1             |

 $A = in1\_tb$   $B = in2\_tb$   $C = in3\_tb$  Z = out1 tb

Figure 3: Truth Table and Port Mapping

The figure below illustrates the verification with assert statements.

```
# vsim work.testbench
# Start time: 14:27:44 on Sep 11,2022
# Loading std.standard
# Loading std.textio(body)
# Loading std.textio(body)
# Loading work.testbench(gate_level)
# Loading work.testbench for input = 000
# Time: 10 ns Iteration: 0 Instance: /testbench
# ** Note: Output correct for input = 010
# Time: 30 ns Iteration: 0 Instance: /testbench
# ** Note: Output correct for input = 010
# Time: 40 ns Iteration: 0 Instance: /testbench
# ** Note: Output correct for input = 100
# Time: 50 ns Iteration: 0 Instance: /testbench
# ** Note: Output correct for input = 101
# Time: 60 ns Iteration: 0 Instance: /testbench
# ** Note: Output correct for input = 110
# Time: 70 ns Iteration: 0 Instance: /testbench
# ** Note: Output correct for input = 111
# Time: 80 ns Iteration: 0 Instance: /testbench
```

Figure 4: Simulation Results with Assert Statements