#### In Test Bench

- 1. Incorrect syntax, missing semicolon in tb
- 2. Incorrect instantiation, missing name and missing required parameter
- 3. Missing code for printing wave to wave generator

#### In Instantiated module,

- 1. Incorrect operator for and, added &
- 2. Incorrect type of variable 'sum'

### **Corrected code**

For test bench:

```
endmodule
```

#### For full adder module:

```
module full_adder(
  input logic a,
  input logic b,
  input logic c,
  output logic sum,
  output logic carry,
);
  assign sum = (a ^ b) ^ c;
  assign carry = (a & b) | (c ^ (a ^ b));
  endmodule
```

## Truth table of the circuit



| Input |   |   | Output |   |
|-------|---|---|--------|---|
| а     | b | С | Х      | У |
| 0     | 0 | 0 | 1      | 0 |
| 0     | 0 | 1 | 0      | 0 |
| 0     | 1 | 0 | 0      | 0 |
| 0     | 1 | 1 | 1      | 0 |
| 1     | 0 | 0 | 0      | 0 |
| 1     | 0 | 1 | 1      | 0 |
| 1     | 1 | 0 | 0      | 1 |
| 1     | 1 | 1 | 1      | 1 |

# SystemVerilog of the given circuit:

```
module Lab03 (input logic a, b, c, output logic x, y);
  logic not_c, or_ab, and_ab, not_and_ab, or_ab_2, xor_out;

not u1(not_c, c);
  or u2(or_ab, a, b);
  nand u3(not_and_ab, a, b);
  xor u4(xor_out, not_and_ab, or_ab);
  and u5(y, or_ab, xor_out);
  xor u6(x, not_c, or_ab);
endmodule
```

# Testbench code of the above code: