# PROJECT STEP 2

**SMARTY PANTS** 

Brian Lee, Chloe Gentry, Vinny Rose

**CS.3339** Computer Architecture

**Texas State University** 

October 28, 2024

## **Contents**

| 1 | Intr         | oduction                   | 1  |  |  |  |  |  |
|---|--------------|----------------------------|----|--|--|--|--|--|
| 2 | 2x4          | Shift Circuit              | 1  |  |  |  |  |  |
|   | 2.1          | Shift Circuit Verilog Code | 1  |  |  |  |  |  |
|   | 2.2          | Shift Circuit Waveforms    | 1  |  |  |  |  |  |
| 3 | Not          | Circuit                    | 2  |  |  |  |  |  |
|   | 3.1          | Not Circuit Verilog Code   | 2  |  |  |  |  |  |
|   | 3.2          | Not Circuit Waveform       | 3  |  |  |  |  |  |
| 4 | And          | Circuit                    | 4  |  |  |  |  |  |
|   | 4.1          | And Circuit Verilog Code   | 4  |  |  |  |  |  |
|   | 4.2          | And Circuit Waveform       | 5  |  |  |  |  |  |
| 5 | Nand Circuit |                            |    |  |  |  |  |  |
|   | 5.1          | Nanad Circuit Verilog Code | 6  |  |  |  |  |  |
|   | 5.2          | Nand Circuit Waveform      | 7  |  |  |  |  |  |
| 6 | Or (         | Circuit                    | 8  |  |  |  |  |  |
|   | 6.1          | Or Circuit Verilog Code    | 8  |  |  |  |  |  |
|   | 6.2          | Or Circuit Waveform        | 9  |  |  |  |  |  |
| 7 | Nor Circuit  |                            |    |  |  |  |  |  |
|   | 7.1          | Nor Circuit Verilog Code   | 9  |  |  |  |  |  |
|   | 7.2          | Nor Circuit Waveform       | 10 |  |  |  |  |  |
| 8 | Xor Circuit  |                            |    |  |  |  |  |  |
|   | 8.1          | Xor Circuit Waveform       | 11 |  |  |  |  |  |
| 9 | XNo          | or Circuit                 | 12 |  |  |  |  |  |

|    | 9.1              | Xnor Circuit Waveform            | 14 |  |  |
|----|------------------|----------------------------------|----|--|--|
| 10 | Addition Circuit |                                  |    |  |  |
|    | 10.1             | Addition Circuit Waveform        | 17 |  |  |
| 11 | Mult             | ciplication Circuit              | 18 |  |  |
|    | 11.1             | Multiplication Circuit Waveform  | 20 |  |  |
| 12 | Subt             | raction Circuit                  | 21 |  |  |
|    | 12.1             | Subtraction Circuit Verilog Code | 21 |  |  |
|    | 12.2             | Subtraction Circuit Waveform     | 22 |  |  |
| 13 | Conc             | clusion                          | 23 |  |  |

#### 1 Introduction

In this project, we implemented essential components of a 4-bit Arithmetic Logic Unit (ALU). First, we coded 4-bit binary logic functions, including AND, NAND, OR, NOR, XOR, XNOR, and NOT, as well as a 2x4-bit input/output shifter. We then implemented 4-bit arithmetic operations such as addition, subtraction, multiplication, and division, integrating carry-in and carry-out circuits for extended accuracy. We included an extra 4-bit output for multiplication and division remainders.

Next, we tested each circuit's functionality to ensure expected behavior, followed by generating simulation waveforms to visually confirm the ALU's performance. Finally, we compiled our work and observations into a comprehensive report, which summarizes the methods, results, and key insights gained from the project.

#### 2 2x4 Shift Circuit

The 2x4 shift circuit takes a 4-bit input and shifts the bits left or right by up to two positions, depending on the control signal. Each shift moves the bits in the input to adjacent positions, and the vacant bits are filled with zeros. Shifting by one or two positions allows for additional flexibility in data manipulation, making the circuit versatile in operations where both single and double shifts are required.

#### 2.1 Shift Circuit Verilog Code

To test the Shift circuit we have created 2 registers, one for the input and one for the shifting then one wire for the output. If this circuit works properly the output should display the input shifted to the left and zeros filling the shifted positions.

#### 2.2 Shift Circuit Waveforms

At 0 ns, we can see that A is 0, so the output Y is 0.

Figure 1: Shift Circuit with marker at 0ns

At 10 ns, A is 1 (0001), so Y becomes 2 (0010).

Figure 2: Shift Circuit with marker at 10ns

At 20 ns, A is 2 (0010), so Y becomes 4 (0100).

Figure 3: Shift Circuit with marker at 20ns

At 30 ns, A is F (1111) so Y becomes E (1110).

Figure 4: Shift Circuit with marker at 30ns

#### 3 Not Circuit

The Not circuit takes one input A, with an output Y. This will output a 0 if A is a 1, and will output 1 if A is a 0.

"

Figure 5: Not truth table and gate

## 3.1 Not Circuit Verilog Code

```
'ifindef NOT_GATE_V

'define NOT_GATE_V

module not_gate (Y, A);

output [3:0] Y; // 4-bit output

input [3:0] A; // 4-bit input

assign Y = ~A;

endmodule

'endif

'endif

'define NOT_GATE_V

A);

continuation

'endif

'endif

'define NOT_GATE_V

A);

continuation

'endif

'endif

'endif

'define NOT_GATE_V

A);

continuation

'endif

'endif
```

To test the Not circuit, we have created one register A, as well as a wire Y. This way we are able to take each input for A and test output for A=0 and A=1. We'll know if this is working correctly if Y returns 1 for the test where A is 0 and Y returns 0 when A is 1.

```
1 'timescale 1ns / 1ns
2 'include "not_gate.v"
3
4 module not_tb;
5
6 reg [3:0]A;
7 wire [3:0]Y;
8
9 not_gate uut(Y, A);
```

```
11 initial begin
      $dumpfile("not_tb.vcd");//holds output waveform
13
      $dumpvars(0, not_tb);
15
           A = 4,00000; #10;
16
           A = 4'b1111; #10;
17
           A = 4, b1010; #10;
18
           A = 4,00101; #10;
19
      $display("Testing not");
22
  end
24
  endmodule
```

#### 3.2 Not Circuit Waveform

At 0 ns, we can see that A is the 0h(0000), so the output Y is Fh(1111).



Figure 6: Not Circuit with marker at 0ns

At 20 ns, A becomes the Ah(1010), so Y becomes the 5h(0101).



Figure 7: Not Circuit with marker at 20ns

At 40 ns, A becomes the 5h(0101), so Y becomes the hex value Ah(1010).



Figure 8: Not Circuit with marker at 40ns

#### 4 And Circuit

The And circuit takes two 4-bit inputs A and B, with a 4-bit output Y. A and B will undergo the bitwise And operation, and the result will be output to Y. "

Figure 9: And truth table and gate

### 4.1 And Circuit Verilog Code

```
'ifndef AND_GATE_V
'define AND_GATE_V

module and_gate (Y, A, B);

output [3:0] Y;

input [3:0] A, B;

assign Y = A & B;

endmodule

'endif
```

To test the And circuit, we have created two registers A and B, as well as a wire Y. We then create a for loop to produce all 16 possible values for A and B. We will know that our And circuit is behaving as expected if Y produces correct values for all combinations of A and B. For example, if A=0001 and B=0001, the expected result for Y is 0001.

```
'timescale 1ns / 1ns
  'include "and_gate.v"
4 module and_tb;
      reg [3:0] A, B;
      wire [3:0] Y;
      and_gate uut(Y, A, B);
10
      integer i, j;
      initial begin
13
          $dumpfile("and_tb.vcd");\
14
          $dumpvars(0, and_tb);
15
16
17
          // Loop through all 16 possible values of A and B
          for (i = 0; i < 16; i = i + 1) begin
18
```

```
for (j = 0; j < 16; j = j + 1) begin
                   A = i;
20
                   B = j;
                   #10;
                   display("A = \%b, B = \%b, Y = \%b", A, B, Y); // Display A,
23
       B, and Y
               end
           end
25
26
           $display("All combinations tested");
           $finish;
28
29
      end
31 endmodule
```

#### 4.2 And Circuit Waveform

At 1ns, A and B are both 0000, so Y is also 0000



Figure 10: And Circuit with marker at 1ns

At 500ns, A=0011 and B=0010, so Y=0010



Figure 11: And Circuit with marker at 500ns

At 2550ns, A and B are both F (1111), so Y is also F (1111).



Figure 12: And Circuit with marker at 2550ns

## 5 Nand Circuit

The Nand circuit takes two 4-bit inputs A and B, with a 4-bit output Y. A and B will undergo the bitwise Nand operation, and the result will be output to Y.

## 5.1 Nanad Circuit Verilog Code

```
'ifndef NAND_GATE_V

'define NAND_GATE_V

module nand_gate (Y, A, B);

output [3:0] Y;

input [3:0] A, B;

assign Y = ~(A & B);

endmodule

'endif

'endif

'endif

'endif

'define NAND_GATE_V

A, B);

gendred

'endif

'endif
```

To test the Nand circuit, we have created two registers A and B, as well as a wire Y. We then create a for loop to produce all 16 possible values for A and B. We will know that our Nand circuit is behaving as expected if Y produces correct values for all combinations of A and B. For example, if A=0001 and B=0001, the expected result for Y is 1110.

```
1 'timescale 1ns / 1ns
2 'include "nand_gate.v"
3
4 module nand_tb;
5
6 reg [3:0] A, B;
7 wire [3:0] Y;
8
9 nand_gate uut(Y, A, B);
10
```

```
integer i, j;
13 initial begin
      $dumpfile("nand_tb.vcd");
15
      $dumpvars(0, nand_tb);
16
17
      // Loop through all 16 possible values of {\tt A} and {\tt B}
18
      for (i = 0; i < 16; i = i + 1) begin</pre>
19
           for (j = 0; j < 16; j = j + 1) begin
               A = i;
               B = j;
               #10;
23
               display("A = \%b, B = \%b, Y = \%b", A, B, Y); // Display A, B,
24
      and Y
           end
      end
26
27
      $display("All combinations tested");
28
      $finish;
32 endmodule
```

## 5.2 Nand Circuit Waveform

At 1ns, A and B are both 0000, so Y is F (1111).



Figure 13: Nand Circuit with marker at 1ns

At 500ns, A=0011 and B=0010, so Y=D (1101)



Figure 14: Nand Circuit with marker at 500ns

At 2500ns, A and B are both F (1111), so Y is 0000.



Figure 15: Nand Circuit with marker at 560ns

#### 6 Or Circuit

The Or circuit takes two 4-bit inputs A and B, and has a 4-bit output Y. Each bit of Y is the result of a bitwise OR operation applied between corresponding bits in A and B. "'

Figure 16: Or truth table and gate

#### **6.1** Or Circuit Verilog Code

```
'ifndef OR_GATE_V

define OR_GATE_V

module or_gate (Y, A, B);

output [3:0] Y;

input [3:0] A, B;

assign Y = A | B;

endmodule

'endif

'endif

'endif

'endif

'define OR_GATE_V

assign Y = A | B;

endmodule

'endif

'endi
```

To test the Nor circuit, we have created two registers, A and B, as well as a wire Y. This way we are able to take two inputs at a time and test each possible input for the circuit.

We'll know if this is working correctly if Y returns 1 for the test where A and B are 0 and Y should return 0 for the rest.

#### 6.2 Or Circuit Waveform

At 0 ns, A and B are 0, so Y is 1.

Figure 17: Nor Circuit with marker at 0ns

At 10 ns, A is 0 and B is 1, so Y is now 0.

Figure 18: Nor Circuit with marker at 10ns

At 20 ns, A is 1 and B is 0, so Y is still 0.

Figure 19: Nor Circuit with marker at 20ns

At 30 ns, both A and B are 1, so Y again stays 0.

Figure 20: Or Circuit with marker at 30ns

#### 7 Nor Circuit

The Nor circuit takes two inputs, A and B, with an output Y. This will output a 0 if either A or B is a 1, and will only output 1 if A and B are both 0.

"

Figure 21: Nor truth table and gate

#### 7.1 Nor Circuit Verilog Code

```
findef NOR_GATE_V

define NOR_GATE_V

module nor_gate (Y, A, B);

output [3:0] Y;

input [3:0] A, B;

assign Y = !(A | B);

endmodule

fendif
```

To test the Nor circuit, we have created two registers, A and B, as well as a wire Y. This way we are able to take two inputs at a time and test each possible input for the circuit. We'll know if this is working correctly if Y returns 1 for the test where A and B are 0 and Y should return 0 for the rest.

#### 7.2 Nor Circuit Waveform

At 0 ns, A and B are 0, so Y is 1.

Figure 22: Nor Circuit with marker at 0ns

At 10 ns, A is 0 and B is 1, so Y is now 0.

Figure 23: Nor Circuit with marker at 10ns

At 20 ns, A is 1 and B is 0, so Y is still 0.

Figure 24: Nor Circuit with marker at 20ns

At 30 ns, both A and B are 1, so Y again stays 0.

Figure 25: Nor Circuit with marker at 30ns

#### 8 Xor Circuit

The Xor circuit takes two 4-bit inputs A and B, with a 4-bit output Y. A and B will undergo the bitwise Xor operation, and the result will be output to Y.

```
'ifndef XOR_GATE_V

'define XOR_GATE_V

module xor_gate (Y, A, B);

output [3:0] Y;

input [3:0] A, B;

assign Y = A ^ B;

endmodule

'endif

'endif

'endif

'endif

'endif

'define XOR_GATE_V

A, B);

authorized A, B;

continuation A, B;

define XOR_GATE_V

authorized A, B;

define XOR_GATE_V

authorized A, B);

define XOR_GATE
```

To test the Xor circuit, we have created two registers A and B, as well as a wire Y. We then create a for loop to produce all 16 possible values for A and B. We will know that our Xor

circuit is behaving as expected if Y produces correct values for all combinations of A and B. For example, if A=1010 and B=1101, the expected result for Y is 0111.

```
'timescale 1ns / 1ns
'include "xor_gate.v"
4 module xor_tb;
      reg [3:0] A, B;
6
      wire [3:0] Y;
      xor_gate uut(Y, A, B);
9
10
      integer i, j;
11
12
      initial begin
13
          $dumpfile("xor_tb.vcd");
14
          $dumpvars(0, xor_tb);
15
16
          // Loop through all 16 possible values of A and B \,
17
          for (i = 0; i < 16; i = i + 1) begin</pre>
18
               for (j = 0; j < 16; j = j + 1) begin
19
                   A = i;
                   B = j;
                   #10;
                   display("A = \%b, B = \%b, Y = \%b", A, B, Y); // Display A,
23
       B, and Y
               end
24
          end
25
26
          $display("All combinations tested");
27
          $finish;
28
      end
29
31 endmodule
```

#### 8.1 Xor Circuit Waveform

At 1ns, A and B are both 0000, so Y is also 0000.



Figure 26: Xor Circuit with marker at 1ns

At 500ns, A=0011 and B=0010, so Y=0001.



Figure 27: Xor Circuit with marker at 500ns

At 2500ns, A and B are both F, so Y=0000.



Figure 28: Xor Circuit with marker at 2500ns

## 9 XNor Circuit

The Xnor circuit takes two 4-bit inputs A and B, with a 4-bit output Y. A and B will undergo the bitwise Xnor operation, and the result will be output to Y.

```
ifindef xnor_GATE_V
define xnor_GATE_V

module xnor_gate (Y, A, B);
output [3:0] Y; // 4-bit output
input [3:0] A; // 4-bit input
input [3:0] B; // 4-bit input
assign Y = ~(A ^ B);
endmodule
```

```
11 'endif
```

To test the Xnor circuit, we have created two registers A and B, as well as a wire Y. We give the circuit some test cases to test its validity. We will know that our Xnor circuit is behaving as expected if Y produces correct values for all combinations of A and B. For example, if A = 1010 and B = 1101, the expected result for Y is 1000.

```
'timescale 1ns / 1ns
 'include "xnor_gate.v"
4 module xnor_tb;
6 reg [3:0]A;
7 reg [3:0]B;
8 wire [3:0] Y;
xnor_gate uut(
      .Y(Y),
      .A(A),
      .B(B));
integer i; // Loop variable
16 initial begin
17
      $dumpfile("xnor_tb.vcd");//holds output waveform
      $dumpvars(0, xnor_tb);
19
          // Apply test cases
20
          A = 4'b0000; B = 4'b0000; #10;
          A = 4,00000; B = 4,01111; #10;
          A = 4'b1010; B = 4'b0101; #10;
23
          A = 4'b1100; B = 4'b1010; #10;
          A = 4'b1111; B = 4'b1111; #10;
25
          A = 4'b0110; B = 4'b0110; #10;
26
          A = 4'b1001; B = 4'b1001; #10;
          A = 4'b1101; B = 4'b0111; #10;
28
29
      $display("Testing xnor");
31
32
  end
34
35 endmodule
```

#### 9.1 Xnor Circuit Waveform

At 1ns, A and B are both 0h (0000), so Y is Fh(0000).



Figure 29: Xnor Circuit with marker at 1ns

At 20ns, A = Ah (1010) and B = 5h(0101), so Y = 0h (0000).

| Time       | 10 ns | 20 ns | 30 ns | 40 ns | 50 ns | 60 ns | 70 ns      | 80 |
|------------|-------|-------|-------|-------|-------|-------|------------|----|
| A[3:0] =A  | )     | A     | )(C   | )F    | 6     | )9    | )D         |    |
| B[3:0] =5  | F     | 5     | )A    | )F    | (6    | )9    | )(7        |    |
| Y[3:0] = 0 | . 0   |       | /9    | )F    |       |       | <b>\</b> 5 |    |
|            |       |       |       |       |       |       |            |    |

Figure 30: Xor Circuit with marker at 500ns

At 40ns, A and B are both Fh(1111), so Y = Fh(1111).



Figure 31: Xor Circuit with marker at 2500ns

#### 10 Addition Circuit

The Addition circuit takes two 4-bit inputs A and B along with a 1-bit carry in to extend the output range from 15 to 31. The circuit's outputs include a 4-bit output called Sum, along with a 1-bit carry out to accommodate the extended range. The has an intermediary 5-bit variable, full sum, which is used to extract carry out and partial sum. First the full sum is found by adding A, B, and carry in. Then, Sum is assigned to the 4 lower bits of full sum. Then, carry out is assigned to the 5th bit of full sum.

```
1 'ifndef ADDITION_V
2 'define ADDITION_V
3
```

```
4 module addition (
      input [3:0] A,
                              // 4-bit input A
      input [3:0] B,
                              // 4-bit input B
                              // 1-bit carry in
      input carry_in,
      output [3:0] Sum,
                             // 4-bit sum output
      output carry_out
                              // 1-bit carry out
10);
11
      wire [4:0] full_sum; // 5-bit sum to accommodate carry-out
12
13
      // Perform the addition with carry_in
14
15
      assign full_sum = A + B + carry_in;
16
      // Assign the lower 4 bits of the sum to the Sum output
17
      assign Sum = full_sum[3:0];
18
19
      // The 5th bit is the carry_out
20
      assign carry_out = full_sum[4];
21
23 endmodule
25 'endif
```

To test the Addition circuit, we have created two registers A and B, a register carry in, a wire Sum, and a wire carry out. We then perform 5 tests with A, B, and carry in at various values. We will know that the Addition circuit is working as expected if carry out plus Sum produces correct results for every combination of A, B, and carry in that we have tested. For example, if A is 1000, B is 1000, and carry in is 1, then the expected result: Sum is 0001, carry out is 1 for a decimal value of 17.

```
timescale 1ns / 1ns
2 'include "addition.v" // Include the addition module
4 module addition_tb;
      reg [3:0] A, B;
                         // 4-bit inputs
      reg carry_in;
                          // 1-bit carry in
      wire [3:0] Sum;
                          // 4-bit sum output
      wire carry_out;
                          // 1-bit carry out
9
      // Instantiate the addition module
11
      addition uut (
12
          .A(A),
13
```

```
.B(B),
          .carry_in(carry_in),
15
          .Sum(Sum),
16
          .carry_out(carry_out)
      );
18
19
      // Test cases
      initial begin
21
          // Initialize dump file for waveform
22
          $dumpfile("addition_tb.vcd");
          $dumpvars(0, addition_tb);
24
          // Test 1: A = 4'b0001, B = 4'b0010, carry_in = 0
          A = 4,00001;
27
          B = 4,00010;
28
          carry_in = 1, b0;
29
          #10;
30
          $display("Test 1: A = %b, B = %b, carry_in = %b => Sum = %b,
31
      carry_out = %b", A, B, carry_in, Sum, carry_out);
32
          // Test 2: A = 4'b1111, B = 4'b0001, carry_in = 0 (expect carry_out
33
       = 1)
          A = 4'b1111;
34
          B = 4,00001;
          carry_in = 1'b0;
          #10;
37
          $display("Test 2: A = %b, B = %b, carry_in = %b => Sum = %b,
      carry_out = %b", A, B, carry_in, Sum, carry_out);
39
          // Test 3: A = 4'b1010, B = 4'b0101, carry_in = 0
          A = 4, b1010;
41
          B = 4, b0101;
42
          carry_in = 1'b0;
          #10;
44
          $display("Test 3: A = %b, B = %b, carry_in = %b => Sum = %b,
45
      carry_out = %b", A, B, carry_in, Sum, carry_out);
46
          // Test 4: A = 4'b1000, B = 4'b1000, carry_in = 1 (expect carry_out
47
       = 1)
          A = 4, b1000;
          B = 4, b1000;
49
          carry_in = 1'b1;
          #10;
```

```
$display("Test 4: A = %b, B = %b, carry_in = %b => Sum = %b,
      carry_out = %b", A, B, carry_in, Sum, carry_out);
53
          // Test 5: A = 4'b0000, B = 4'b0000, carry_in = 1 (expect carry_out
       = 0)
          A = 4, b0000;
55
          B = 4,00000;
          carry_in = 1'b1;
57
          #10;
58
          $display("Test 5: A = %b, B = %b, carry_in = %b => Sum = %b,
      carry_out = %b", A, B, carry_in, Sum, carry_out);
60
          // Finish simulation
          $finish;
62
63
65 endmodule
```

#### 10.1 Addition Circuit Waveform

At 2ns, A is 1 and B is 2, so Sum is 3 with carry in and carry out at 0.



Figure 32: Addition Circuit with marker at 2ns

At 20ns, A is A(1010) and B is 5(0101), so Sum is F(1111) with carry in and carry out at 0.



Figure 33: Addition Circuit with marker at 20ns

At 30ns, A and B are both 8(1000), so Sum is 1 with carry in and carry out at 1, resulting in a decimal value of 17.



Figure 34: Addition Circuit with marker at 30ns

## 11 Multiplication Circuit

The Multiplication circuit takes two 4-bit inputs A and B, and produces two 4-bit outputs, product low and product high, representing the high and low 4 bits of the product of A and B. The circuit has an intermediary 8-bit variable, full product, which is used to extract the low and high 4 bits of the product. First, full product is assigned to the product of A and B. Then, product low is assigned the first 4 bits of full product. Then, product high is assigned the last 4 bits of full product.

```
'ifndef MULTIPLICATION_V

'define MULTIPLICATION_V

module multiplier_4bit (
   input [3:0] A, B,
   output [3:0] product_low, // Lower 4 bits of the product
   output [3:0] product_high // Upper 4 bits of the product
```

```
8 );
9  wire [7:0] full_product;  // 8-bit wire to hold the full product
10
11  assign full_product = A * B;
12  assign product_low = full_product[3:0];  // Lower 4 bits
13  assign product_high = full_product[7:4];  // Upper 4 bits
14 endmodule
15
16 'endif
```

To test the Multiplication circuit, we have created two registers A and B, and two wires product low and product high. We then perform 5 tests with A and B at various values. We will know that the Multiplication circuit is working as expected if product low, product high produces correct results for every combination of A times B that we have tested. For example, if A is 1111 and B is 1111, then the expected result: product high is 1110, product low is 0001 for a decimal value of 225.

```
'timescale 1ns / 1ns
  'include "multiplication.v"
4 module multiplication_tb;
      reg [3:0] A, B;
      wire [3:0] product_low;
      wire [3:0] product_high;
      multiplier_4bit uut (
          .A(A),
11
          .B(B),
          .product_low(product_low),
13
          .product_high(product_high)
14
      );
15
      initial begin
17
          $dumpfile("multiplication_tb.vcd");
18
          $dumpvars(0, multiplication_tb);
20
          A = 4'b0010; B = 4'b0011; #10;
21
          $display("A = %b, B = %b, product_low = %b, product_high = %b", A,
22
     B, product_low, product_high);
23
          A = 4'b0101; B = 4'b0101; #10;
24
```

```
$display("A = %b, B = %b, product_low = %b, product_high = %b", A,
     B, product_low, product_high);
26
          A = 4'b0110; B = 4'b0011; #10;
27
          $display("A = %b, B = %b, product_low = %b, product_high = %b", A,
28
     B, product_low, product_high);
          A = 4'b1001; B = 4'b0100; #10;
30
          $display("A = %b, B = %b, product_low = %b, product_high = %b", A,
31
     B, product_low, product_high);
32
          A = 4'b1111; B = 4'b1111; #10;
33
          $display("A = %b, B = %b, product_low = %b, product_high = %b", A,
34
     B, product_low, product_high);
35
          $display("Selected test cases completed");
          $finish;
37
      end
38
40 endmodule
```

#### 11.1 Multiplication Circuit Waveform

At 2ns, A is 2 and B is 3, so product high is 0 and product low is 6.



Figure 35: Multiplication Circuit with marker at 2ns

At 20ns, A is 6 and B is 3, so product upper is 0001 and product lower is 0010 for a decimal value of 18.



Figure 36: Multiplication Circuit with marker at 20ns

At 40ns, A and B are both F, so product upper is E and product lower is 0001 for a decimal value of 256.



Figure 37: Multiplication Circuit with marker at 40ns

#### 12 Subtraction Circuit

## 12.1 Subtraction Circuit Verilog Code

```
ifindef SUBTRACTION_V
define SUBTRACTION_V

module subtraction (Y, A, B);
  output [3:0] Y;  // 4-bit output
  input [3:0] A;  // 4-bit input A
  input [3:0] B;  // 4-bit input B

sassign Y = A - B;  // Perform 4-bit subtraction

endmodule

'timescale 1ns / 1ns
'include "subtraction.v"

ifinal content in the subtraction in the su
```

```
4 module subtraction_tb;
                        // 4-bit input A
      reg [3:0] A;
6
      reg [3:0] B;
                        // 4-bit input B
      wire [3:0] Y;
                        // 4-bit output Y (result of A - B)
10
      subtraction uut (Y, A, B);
11
      initial begin
12
          $dumpfile("subtraction_tb.vcd"); // Holds output waveform
13
          $dumpvars(0, subtraction_tb);
14
15
          // Test cases for 4-bit subtraction
          A = 4'b0001; B = 4'b0001; #10; // Expected Y: 0000
          A = 4'b1010; B = 4'b0011; #10; // Expected Y: 0111
18
          A = 4'b1100; B = 4'b0101; #10; // Expected Y: 1001
          A = 4'b1111; B = 4'b1110; #10; // Expected Y: 0001
20
          A = 4'b0101; B = 4'b1001; #10; // Expected Y: Overflow
21
22
          $display("Testing subtraction");
      end
24
26 endmodule
```

#### 12.2 Subtraction Circuit Waveform

At 0ns, A is 1h (0001) and B is 1h (0001), so Y = 0h (0000)



Figure 38: Subtraction Circuit with marker at Ons

At 0ns, A is Ch (1100) and B is 5h (0101), so Y = 7h (0111)



Figure 39: Subtraction Circuit with marker at 20ns

At 0ns, A is 5h (0101) and B is 9h (1001), so Y = Ch (1100)



Figure 40: Multiplication Circuit with marker at 40ns

#### 13 Conclusion

This project introduced the design and testing of a basic 4-bit Arithmetic Logic Unit (ALU). We coded essential logic functions like AND, OR, and NOT, along with shifting operations, which are crucial for handling binary data. We also developed basic arithmetic operations—addition, subtraction, multiplication, and division—which included handling carries and remainders to ensure accurate results.

Testing the circuits and generating waveforms confirmed that our ALU worked correctly across different inputs. This process highlighted the importance of both accuracy in coding and thorough testing. Overall, the project has been valuable for understanding digital circuits and the structure of an ALU, preparing us for more advanced digital logic design.