## **Timing Chart**

|                    |          |          |            |            |            |            |            |            |                  |          | 1,000.000  |
|--------------------|----------|----------|------------|------------|------------|------------|------------|------------|------------------|----------|------------|
| Name               | Value    | 0.000 ns | 100.000 ns | 200.000 ns | 300.000 ns | 400.000 ns | 500.000 ns | 600.000 ns | 700.000 ns  800. | .000 ns  | 900.000 ns |
| > <b>W</b> A[3:0]  | a        |          |            |            |            |            | a          |            |                  |          |            |
| > ₩ B[3:0]         | 6        |          |            |            |            |            | 6          |            |                  |          |            |
| V Select[2:0]      | 7        | 0        | 1          | 2          | 3          | 4          | 5          | 6          | \<br>\           | 7        |            |
| <sup>↓</sup> Cin   | 1        |          |            |            |            |            |            |            |                  |          |            |
| ♥ Out[3:0]         | 0        | 1        | 3          | е          | 2          | 4          | 5          | <b>/</b>   | 0                |          |            |
| <b>¼</b> Cout      | 0        |          |            |            |            |            |            |            |                  |          |            |
| > <b>™</b> i[31:0] | 00000007 | 00000000 | 00000001   | 00000002   | 00000003   | 00000004   | 00000005   | 00000006   |                  | 00000007 |            |
|                    |          |          |            |            |            |            |            |            |                  |          |            |

#### Lab6.v

```
Lab6.v U X Lab6_tb.v U
Lab-6 > Lab-6.srcs > sources_1 > new > • Lab6.v > ...
      `timescale 1ns / 1ps
      module ALU_4b (
           input [3:0] A, B,
           input Cin,
           input [2:0] Select,
           output reg [3:0] Out,
           output reg Cout
      );
           always @( A, B, Cin, Select ) begin
              case( Select )
                  3'b000: { Cout, Out } <= A + B + Cin;
                  3'b001: { Cout, Out } <= A - B - Cin;
                  3'b010: { Cout, Out } <= A / B;
                  3'b011: { Cout, Out } <= A & B;
                  3'b100: { Cout, Out } <= A << 1'b1;
                  3'b101: { Cout, Out } <= A >> 1'b1;
                  3'b110: { Cout, Out } <= A[2:0] & A[3];
                   3'b111: { Cout, Out } <= A[0] & A[3:1];
              endcase
          end
       endmodule
```

## Lab6\_tb.v

```
Lab6v U Lab6dbv U X

Lab6 > Lab-6ars > sim_1 > new > * Lab6_tbv > v' Lab6_tb

module Lab6_tb();

module Lab6_tb();

reg [3:8] A, 8;

reg [3:9] Select;

reg Cin;

wire (3:0] Out;

wire (3:0] Out;

wire Cout;

ALU_ab alu(A, B, Cin, Select, Out, Cout );

integer i;

intital begin

A = 4'b010;

Cin = 1'b1;

Select = 3'b000;

$monitor("\nselect: %b\n\nA: %b\nB: %b\nCin: %b\nOut: %b\nCout: %b\n", select, A, B, Cin, Out, Cout );

for (i = 0; i < 7; i = i + 1) begin

#100

$monitor("\nselect: %b\n\nA: %b\nB: %b\nCin: %b\nOut: %b\nCout: %b\n", select, A, B, Cin, Out, Cout );

$monitor("\nselect: %b\n\nA: %b\nB: %b\nCin: %b\nOut: %b\nCout: %b\n", select, A, B, Cin, Out, Cout );

$monitor("\nselect: %b\n\nA: %b\nB: %b\nCin: %b\nOut: %b\nCout: %b\n", select, A, B, Cin, Out, Cout );

$monitor("\nselect: %b\n\nA: %b\nB: %b\nCin: %b\nOut: %b\nCout: %b\n", select, A, B, Cin, Out, Cout );

$monitor("\nselect: %b\n\nA: %b\nB: %b\nCin: %b\nOut: %b\nCout: %b\n", select, A, B, Cin, Out, Cout );

$monitor("\nselect: %b\n\nA: %b\nB: %b\nCin: %b\nOut: %b\nCout: %b\n", select, A, B, Cin, Out, Cout );

$monitor("\nselect: %b\n\nA: %b\nB: %b\nCin: %b\nOut: %b\nCut: %b\n", select, A, B, Cin, Out, Cout );

$monitor("\nselect: %b\n\nA: %b\nB: %b\nCin: %b\nOut: %b\nCut: %b\n", select, A, B, Cin, Out, Cout );
```

## **TCL Console**

| Select: 000 |
|-------------|
| A: 1010     |
| B: 0110     |
| Cin: 1      |
| Out: 0001   |
| Cout: 1     |
|             |
|             |
|             |
| Select: 001 |
| A. 1010     |
| A: 1010     |
| B: 0110     |
| Cin: 1      |
| Out: 0011   |
| Cout: 0     |
|             |
|             |
| Select: 001 |
| Select: 001 |
| A: 1010     |
| B: 0110     |
| Cin: 1      |
| Out: 0011   |

# Abhi Rangarajan uxs876 Cout: 0 Select: 010 A: 1010 B: 0110 Cin: 1 Out: 1110 Cout: 0 Select: 010 A: 1010 B: 0110 Cin: 1 Out: 1110 Cout: 0 Select: 011 A: 1010 B: 0110 Cin: 1 Out: 0010

Cout: 0

Out: 0100

Cout: 1

### Abhi Rangarajan uxs876

| Select: 101 |
|-------------|
| A: 1010     |
| B: 0110     |
| Cin: 1      |
| Out: 0101   |
| Cout: 0     |
|             |
|             |
| Select: 101 |
| A: 1010     |
| B: 0110     |
| Cin: 1      |
| Out: 0101   |
| Cout: 0     |
|             |
| Select: 110 |
| A: 1010     |
| B: 0110     |
| Cin: 1      |
| Out: 0000   |
| Cout: 0     |

| Abhi Rangarajan uxs876 |
|------------------------|
|                        |
| Select: 110            |
| A: 1010                |
| B: 0110                |
| Cin: 1                 |
| Out: 0000              |
| Cout: 0                |
|                        |
| Select: 111            |
| A: 1010                |
| B: 0110                |
| Cin: 1                 |
| Out: 0000              |
| Cout: 0                |
|                        |
|                        |
| Select: 111            |
| A: 1010                |
| B: 0110                |
| Cin: 1                 |
| Out: 0000              |

Cout: 0