

P1)

## 1. Testbench code



```
1 import testing_pkg::*;
2 module ALU_tb();
3     Transaction obj = new ;
4     byte operand1 , operand2 ;
5     bit clk , rst ;
6     opcode_e opcode ;
7     byte out ;
8     byte expected_out ;
9
10    alu_seq DUT (operand1, operand2, clk, rst, opcode, out) ;
11
12    integer correct_count , error_count ;
13
14    initial begin
15        clk = 0;
16        forever begin
17            #2 clk = ~clk;
18            obj.clk = clk;
19        end
20    end
21
22    initial begin
23        rst = 0 ;
24        correct_count = 0 ;
25        error_count = 0 ;
26        check_result () ;
27        repeat (30000) begin
28            assert (obj.randomize()) ;
29            operand1 = obj.operand1 ;
30            operand2 = obj.operand2 ;
31            opcode = obj.opcode ;
32            golden_model () ;
33            check_result () ;
34        end
35
36        check_result() ;
37
38        $display ("correct counter = %d , error counter = %d " , correct_count , error_count ) ;
39        $stop ;
40    end
41
42
43    task golden_model ();
44        if (rst)
45            expected_out = 0 ;
46        else begin
47            case (opcode)
48                ADD : expected_out = operand1 + operand2 ;
49                SUB : expected_out = operand1 - operand2 ;
50                MULT: expected_out = operand1 * operand2 ;
51                DIV : expected_out = operand1 / operand2 ;
52            endcase
53        end
54    endtask
55
56    task check_result ();
57        @(negedge clk) ;
58        if (expected_out == out) begin
59            $display ("test passes") ;
60            correct_count = correct_count + 1 ;
61        end
62        else begin
63            $display ("test fail ") ;
64            error_count = error_count + 1 ;
65        end
66    endtask
67
68    task assert_reset();
69        rst = 1 ;
70        expected_out = 0 ;
71        @(negedge clk) ;
72        if (expected_out == out) begin
73            $display ("test passes") ;
74            correct_count = correct_count + 1 ;
75        end
76        else begin
77            $display ("test fail ") ;
78            error_count = error_count + 1 ;
79        end
80        rst = 0 ;
81    endtask
82 endmodule
```

## 2. Package code

```

1 package testing_pkg;
2   typedef enum logic [1:0] { ADD , SUB , MULT , DIV } opcode_e;
3
4   class Transaction;
5     rand opcode_e opcode ;
6     rand byte operand1 ;
7     rand byte operand2 ;
8     bit clk ;
9
10    constraint operand1_constraint {
11      operand1 dist {127:/25 , 0:/25 , -128:/25 , [1:126]:/15 , [-127:-1]:/10} ;
12    }
13
14    constraint operand2_constraint {
15      operand2 dist {127:/25 , 0:/25 , -128:/25 , [1:126]:/15 , [-127:-1]:/10} ;
16    }
17
18    covergroup covcode @(posedge clk) ;
19      cv1: coverpoint opcode {
20        bins opbin1 = {ADD,SUB} ;
21        bins opbin2 = {ADD => SUB} ;
22        bins op_ADD = {ADD} ;
23        bins op_SUB = {SUB} ;
24        bins op_MULT = {MULT} ;
25        bins opbin3 = default ;
26        illegal_bins invalid = {DIV} ;
27      }
28
29      cv2: coverpoint operand1 {
30        bins max_pos = {127} ;
31        bins ZERO = {0} ;
32        bins max_neg = {-128} ;
33        bins other = default ;
34      }
35
36      cv3: coverpoint operand2 {
37        bins max_pos = {127} ;
38        bins ZERO = {0} ;
39        bins max_neg = {-128} ;
40        bins other = default ;
41      }
42
43      cv4 : cross cv1 ,cv2 , cv3 {
44        bins max_pos1_max_pos2_ADD = binsof (cv1.op_ADD) && binsof (cv2.max_pos) && binsof (cv3.max_pos) ;
45        bins max_pos1_max_neg2_ADD = binsof (cv1.op_ADD) && binsof (cv2.max_pos) && binsof (cv3.max_neg) ;
46        bins max_pos1_zero2_ADD = binsof (cv1.op_ADD) && binsof (cv2.max_pos) && binsof (cv3.ZERO) ;
47        bins max_neg1_max_pos2_ADD = binsof (cv1.op_ADD) && binsof (cv2.max_neg) && binsof (cv3.max_pos) ;
48        bins max_neg1_max_neg2_ADD = binsof (cv1.op_ADD) && binsof (cv2.max_neg) && binsof (cv3.max_neg) ;
49        bins max1_zero2_ADD = binsof (cv1.op_ADD) && binsof (cv2.ZERO) && binsof (cv3.ZERO) ;
50        bins zero1_max_pos2_ADD = binsof (cv1.op_ADD) && binsof (cv2.ZERO) && binsof (cv3.max_pos) ;
51        bins zero1_max_neg2_ADD = binsof (cv1.op_ADD) && binsof (cv2.ZERO) && binsof (cv3.max_neg) ;
52        bins zero1_zero2_ADD = binsof (cv1.op_ADD) && binsof (cv2.ZERO) && binsof (cv3.ZERO) ;
53
54        bins max_pos1_max_pos2_SUB = binsof (cv1.op_SUB) && binsof (cv2.max_pos) && binsof (cv3.max_pos) ;
55        bins max_pos1_max_neg2_SUB = binsof (cv1.op_SUB) && binsof (cv2.max_pos) && binsof (cv3.max_neg) ;
56        bins max_pos1_zero2_SUB = binsof (cv1.op_SUB) && binsof (cv2.max_pos) && binsof (cv3.ZERO) ;
57        bins max_neg1_max_pos2_SUB = binsof (cv1.op_SUB) && binsof (cv2.max_neg) && binsof (cv3.max_pos) ;
58        bins max_neg1_max_neg2_SUB = binsof (cv1.op_SUB) && binsof (cv2.max_neg) && binsof (cv3.max_neg) ;
59        bins max_neg1_zero2_SUB = binsof (cv1.op_SUB) && binsof (cv2.max_neg) && binsof (cv3.ZERO) ;
60        bins zero1_max_pos2_SUB = binsof (cv1.op_SUB) && binsof (cv2.ZERO) && binsof (cv3.max_pos) ;
61        bins zero1_max_neg2_SUB = binsof (cv1.op_SUB) && binsof (cv2.ZERO) && binsof (cv3.max_neg) ;
62        bins zero1_zero2_SUB = binsof (cv1.op_SUB) && binsof (cv2.ZERO) && binsof (cv3.ZERO) ;
63
64        bins max_pos1_max_pos2_MULT = binsof (cv1.op_MULT) && binsof (cv2.max_pos) && binsof (cv3.max_pos) ;
65        bins max_pos1_max_neg2_MULT = binsof (cv1.op_MULT) && binsof (cv2.max_pos) && binsof (cv3.max_neg) ;
66        bins max_pos1_zero2_MULT = binsof (cv1.op_MULT) && binsof (cv2.max_pos) && binsof (cv3.ZERO) ;
67        bins max_neg1_max_pos2_MULT = binsof (cv1.op_MULT) && binsof (cv2.max_neg) && binsof (cv3.max_pos) ;
68        bins max_neg1_max_neg2_MULT = binsof (cv1.op_MULT) && binsof (cv2.max_neg) && binsof (cv3.max_neg) ;
69        bins max1_zero2_MULT = binsof (cv1.op_MULT) && binsof (cv2.ZERO) && binsof (cv3.ZERO) ;
70        bins zero1_max_pos2_MULT = binsof (cv1.op_MULT) && binsof (cv2.ZERO) && binsof (cv3.max_pos) ;
71        bins zero1_max_neg2_MULT = binsof (cv1.op_MULT) && binsof (cv2.ZERO) && binsof (cv3.max_neg) ;
72        bins zero1_zero2_MULT = binsof (cv1.op_MULT) && binsof (cv2.ZERO) && binsof (cv3.ZERO) ;
73      }
74    endgroup
75
76    function new ();
77      covcode = new () ;
78    endfunction
79
80  endclass
81 endpackage

```

### 3. Design code



```
1 import testing_pkg::*;
2 module alu_seq(operand1, operand2, clk, rst, opcode, out);
3   input byte operand1, operand2;
4   input clk, rst;
5   input opcode_e opcode;
6   output byte out;
7
8   always @(posedge clk) begin
9     if (rst)
10       out <= 0;
11     else
12       case (opcode)
13         ADD: out <= operand1 + operand2;
14         SUB: out <= operand1 - operand2;
15         MULT:out <= operand1 * operand2;
16         DIV: out <= operand1 / operand2;
17         default: out <= 0;
18     endcase
19   end
20 endmodule
```

### 4. Snippet to your verification plan document

| A<br>Label | B<br>Design Requirement Description                                                              | C<br>Stimulus Generation                                                                                                                                                                                | D<br>Functional Coverage                                                                                                                                                                                                 | E<br>Functionality Check                                      |
|------------|--------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|
| TEST_1     | When the reset is asserted by task <code>assert_reset</code> , the output value should be low    | Directed at the start of the simulation, then randomized with constraint that drive the reset to be most of the simulation off                                                                          |                                                                                                                                                                                                                          | A checker in the testbench to make sure the output is correct |
| TEST_2     | when the reset is deasserted the output of the design should be equal the output of golden model | Randomized under constrains on the A & B values to be 25% of simulation with MAXPOS value , 25% of simulation with MAXNEG value, 25% of simulation with ZERO and remain of simulation with other values | Ensure all values of operand A are covered.<br>Ensure all values of operand B are covered.<br>Ensure all opcode operations are exercised.<br>Ensure all maximum combinations of A, B, and opcode operations are covered. | A checker in the testbench to make sure the output is correct |
| TEST_3     | When the reset is asserted, the output value should be low                                       | Directed at the end of the simulation                                                                                                                                                                   |                                                                                                                                                                                                                          | A checker in the testbench to make sure the output is correct |

## 5. Do file



```
1 vlib work
2 vlog alu.svh package.svh module.svh +cover -covercells
3 vsim -voptargs=+acc work.ALU_tb -cover
4 add wave *
5 coverage save alu_seq.ucdb -onexit -du alu_seq
6 run -all
```

## 6. Code Coverage report snippets

| TYPE                                                     | /testing_pkg/Transaction/covcode | 100.00% | 100 | - | Covered  |
|----------------------------------------------------------|----------------------------------|---------|-----|---|----------|
| covered/total bins:                                      | 56                               | 56      | -   | - |          |
| missing/total bins:                                      | 0                                | 56      | -   | - |          |
| % Hit:                                                   | 100.00%                          | 100     | -   | - |          |
| Coverpoint cv1                                           | 100.00%                          | 100     | -   | - | Covered  |
| covered/total bins:                                      | 5                                | 5       | -   | - |          |
| missing/total bins:                                      | 0                                | 5       | -   | - |          |
| % Hit:                                                   | 100.00%                          | 100     | -   | - |          |
| Coverpoint cv2                                           | 100.00%                          | 100     | -   | - | Covered  |
| covered/total bins:                                      | 3                                | 3       | -   | - |          |
| missing/total bins:                                      | 0                                | 3       | -   | - |          |
| % Hit:                                                   | 100.00%                          | 100     | -   | - |          |
| Coverpoint cv3                                           | 100.00%                          | 100     | -   | - | Covered  |
| covered/total bins:                                      | 3                                | 3       | -   | - |          |
| missing/total bins:                                      | 0                                | 3       | -   | - |          |
| % Hit:                                                   | 100.00%                          | 100     | -   | - |          |
| Cross cv4                                                | 100.00%                          | 100     | -   | - | Covered  |
| covered/total bins:                                      | 45                               | 45      | -   | - |          |
| missing/total bins:                                      | 0                                | 45      | -   | - |          |
| % Hit:                                                   | 100.00%                          | 100     | -   | - |          |
| Covergroup instance \:/testing_pkg::Transaction::covcode | 100.00%                          | 100     | -   | - | Covered  |
| covered/total bins:                                      | 56                               | 56      | -   | - |          |
| missing/total bins:                                      | 0                                | 56      | -   | - |          |
| % Hit:                                                   | 100.00%                          | 100     | -   | - |          |
| Coverpoint cv1                                           | 100.00%                          | 100     | -   | - | Covered  |
| covered/total bins:                                      | 5                                | 5       | -   | - |          |
| missing/total bins:                                      | 0                                | 5       | -   | - |          |
| % Hit:                                                   | 100.00%                          | 100     | -   | - |          |
| illegal_bin invalid                                      | 7568                             | -       | -   | - | Occurred |
| bin_opbin1                                               | 14787                            | 1       | -   | - | Covered  |
| bin_opbin2                                               | 1747                             | 1       | -   | - | Covered  |
| bin_op_ADD                                               | 7467                             | 1       | -   | - | Covered  |
| bin_op_SUB                                               | 7320                             | 1       | -   | - | Covered  |
| bin_op_MULT                                              | 7646                             | 1       | -   | - | Covered  |
| default_bin opbin3                                       | 0                                | -       | -   | - | ZERO     |
| Coverpoint cv2                                           | 100.00%                          | 100     | -   | - | Covered  |
| covered/total bins:                                      | 3                                | 3       | -   | - |          |
| missing/total bins:                                      | 0                                | 3       | -   | - |          |
| % Hit:                                                   | 100.00%                          | 100     | -   | - |          |
| bin_max_pos                                              | 7409                             | 1       | -   | - | Covered  |
| bin_ZERO                                                 | 7510                             | 1       | -   | - | Covered  |
| bin_max_neg                                              | 7511                             | 1       | -   | - | Covered  |
| default_bin other                                        | 7571                             | -       | -   | - | Occurred |

|                                      |             |         |       |             |
|--------------------------------------|-------------|---------|-------|-------------|
| Coverpoint cv3                       | 100.00%     | 100     | -     | Covered     |
| covered/total bins:                  | 3           | 3       | -     |             |
| missing/total bins:                  | 0           | 3       | -     |             |
| % Hit:                               | 100.00%     | 100     | -     |             |
| bin max_pos                          | 7420        | 1       | -     | Covered     |
| bin ZERO                             | 7574        | 1       | -     | Covered     |
| bin max_neg                          | 7486        | 1       | -     | Covered     |
| default bin other                    | 7521        | 1       | -     | Occurred    |
| <br>Cross cv4                        | <br>100.00% | <br>100 | <br>- | <br>Covered |
| covered/total bins:                  | 45          | 45      | -     |             |
| missing/total bins:                  | 0           | 45      | -     |             |
| % Hit:                               | 100.00%     | 100     | -     |             |
| Auto, Default and User Defined Bins: |             |         |       |             |
| bin max_pos1_max_pos2_ADD            | 454         | 1       | -     | Covered     |
| bin max_pos1_max_neg2_ADD            | 470         | 1       | -     | Covered     |
| bin max_pos1_zero2_ADD               | 452         | 1       | -     | Covered     |
| bin max_neg1_max_pos2_ADD            | 465         | 1       | -     | Covered     |
| bin max_neg1_max_neg2_ADD            | 503         | 1       | -     | Covered     |
| bin max_neg1_zero2_ADD               | 463         | 1       | -     | Covered     |
| bin zero1_max_pos2_ADD               | 460         | 1       | -     | Covered     |
| bin zero1_max_neg2_ADD               | 471         | 1       | -     | Covered     |
| bin zero1_zero2_ADD                  | 490         | 1       | -     | Covered     |
| bin max_pos1_max_pos2_SUB            | 450         | 1       | -     | Covered     |
| bin max_pos1_max_neg2_SUB            | 427         | 1       | -     | Covered     |
| bin max_pos1_zero2_SUB               | 475         | 1       | -     | Covered     |
| bin max_neg1_max_pos2_SUB            | 479         | 1       | -     | Covered     |
| bin max_neg1_max_neg2_SUB            | 503         | 1       | -     | Covered     |
| bin max_neg1_zero2_SUB               | 434         | 1       | -     | Covered     |
| bin zero1_max_pos2_SUB               | 436         | 1       | -     | Covered     |
| bin zero1_max_neg2_SUB               | 455         | 1       | -     | Covered     |
| bin zero1_zero2_SUB                  | 461         | 1       | -     | Covered     |
| bin max_pos1_max_pos2_MULT           | 415         | 1       | -     | Covered     |
| bin max_pos1_max_neg2_MULT           | 466         | 1       | -     | Covered     |
| bin max_pos1_zero2_MULT              | 490         | 1       | -     | Covered     |
| bin max_neg1_max_pos2_MULT           | 503         | 1       | -     | Covered     |
| bin max_neg1_max_neg2_MULT           | 465         | 1       | -     | Covered     |
| bin max_neg1_zero2_MULT              | 458         | 1       | -     | Covered     |
| bin zero1_max_pos2_MULT              | 503         | 1       | -     | Covered     |
| bin zero1_max_neg2_MULT              | 465         | 1       | -     | Covered     |
| bin zero1_zero2_MULT                 | 493         | 1       | -     | Covered     |
| bin <opbin2,max_neg,max_neg>         | 110         | 1       | -     | Covered     |
| bin <opbin1,max_neg,max_neg>         | 1006        | 1       | -     | Covered     |
| bin <opbin2,max_neg,ZERO>            | 105         | 1       | -     | Covered     |
| bin <opbin1,max_neg,ZERO>            | 897         | 1       | -     | Covered     |
| bin <opbin2,max_neg,max_pos>         | 112         | 1       | -     | Covered     |
| bin <opbin1,max_neg,max_pos>         | 944         | 1       | -     | Covered     |
| bin <opbin2,ZERO,max_neg>            | 109         | 1       | -     | Covered     |
| bin <opbin1,ZERO,max_neg>            | 926         | 1       | -     | Covered     |
| bin <opbin2,max_pos,max_neg>         | 95          | 1       | -     | Covered     |
| bin <opbin1,max_pos,max_neg>         | 897         | 1       | -     | Covered     |
| bin <opbin2,ZERO,ZERO>               | 105         | 1       | -     | Covered     |
| bin <opbin1,ZERO,ZERO>               | 951         | 1       | -     | Covered     |
| bin <opbin2,max_pos,ZERO>            | 99          | 1       | -     | Covered     |
| bin <opbin1,max_pos,ZERO>            | 927         | 1       | -     | Covered     |
| bin <opbin2,ZERO,max_pos>            | 101         | 1       | -     | Covered     |
| bin <opbin1,ZERO,max_pos>            | 896         | 1       | -     | Covered     |
| <br>bin <opbin2,max_pos,max_neg>     | <br>95      | <br>1   | <br>- | <br>Covered |
| bin <opbin1,max_pos,max_neg>         | 897         | 1       | -     | Covered     |
| bin <opbin2,ZERO,ZERO>               | 105         | 1       | -     | Covered     |
| bin <opbin1,ZERO,ZERO>               | 951         | 1       | -     | Covered     |
| bin <opbin2,max_pos,ZERO>            | 99          | 1       | -     | Covered     |
| bin <opbin1,max_pos,ZERO>            | 927         | 1       | -     | Covered     |
| bin <opbin2,ZERO,max_pos>            | 101         | 1       | -     | Covered     |
| bin <opbin1,ZERO,max_pos>            | 896         | 1       | -     | Covered     |
| bin <opbin2,max_pos,max_pos>         | 120         | 1       | -     | Covered     |
| bin <opbin1,max_pos,max_pos>         | 904         | 1       | -     | Covered     |

TOTAL COVERGROUP COVERAGE: 100.00% COVERGROUP TYPES: 1

Total Coverage By Instance (filtered view): 100.00%



## 7. Functional Coverage report snippets (Questions 1, 2, and 3 only)

```

# Coverage Report by instance with details
#
# =====
# === Instance: /\ALU_tb#DUT
# === Design Unit: work.alu_seq
# =====
# Branch Coverage:
#   Enabled Coverage      Bins    Hits    Misses  Coverage
#   -----      -----  -----  -----
#   Branches           6       6       0     100%
#
# ======Branch Details=====
#
# Branch Coverage for instance /\ALU_tb#DUT
#
# Line      Item          Count      Source
# ----      ---          -----      -----
# File alu.svh
# -----IF Branch-----
#   9           29935  Count coming in to IF
#   9           1           2      if (rst)
#
#   11          1           29933  else
#
# Branch totals: 2 hits of 2 branches = 100.00%
#
# -----CASE Branch-----
#   12          29933  Count coming in to CASE
#   13          7509      ADD: out <= operand1 + operand2;
#
#   14          7515      SUB: out <= operand1 - operand2;
#
#   15          7464      MULT:out <= operand1 * operand2;
#
#   16          7445      DIV: out <= operand1 / operand2;
#
# Branch totals: 4 hits of 4 branches = 100.00%
#
#

```

```

#
# Toggle Coverage:
#   Enabled Coverage      Bins    Hits    Misses Coverage
#   -----      -----  -----  -----  -----
#   Toggles          56      56      0   100.00%
#
# =====Toggle Details=====
#
# Toggle Coverage for instance /\ALU_tb#DUT --
#
#                                     Node  1H->0L  0L->1H           "Coverage"
#                                     -----  -----  -----
#                                     clk     1       1           100.00
#                                     opcode ENUM type  Value  Count
#                                         ADD      1   100.00
#                                         SUB      2   100.00
#                                         MULT     1   100.00
#                                         DIV      1   100.00
#                                     operand1[7-0]  1       1           100.00
#                                     operand2[7-0]  1       1           100.00
#                                     out[7-0]    1       1           100.00
#                                     rst       1       1           100.00
#
# Total Node Count      =      30
# Toggled Node Count   =      30
# Untoggled Node Count =      0
#
# Toggle Coverage      =      100.00% (56 of 56 bins)
#
#
# Total Coverage By Instance (filtered view): 100%
#
# End time: 20:22:34 on Sep 09, 2025, Elapsed time: 0:00:00
# Errors: 0, Warnings: 0

```

## 8. Clear and neat QuestaSim waveform snippets showing the functionality of the design



P2)

## 1. Testbench code

```
1 import counter_package::*;
2 module counter_tb();
3   parameter WIDTH = 4;
4   reg clk_tb;
5   reg rst_n_tb;
6   reg load_n_tb;
7   reg up_down_tb;
8   reg ce_tb;
9   reg [WIDTH-1:0] data_load_tb;
10  reg [WIDTH-1:0] out_expected;
11  wire [WIDTH-1:0] count_out_tb;
12
13  wire max_count_tb;
14  wire zero_tb;
15  reg zero_flag_expected;
16  reg max_count_flag_expected;
17  counter_class obj1 = new;
18
19  counter #(WIDTH(4)) DUT (clk_tb ,rst_n_tb, load_n_tb, up_down_tb, ce_tb, data_load_tb, count_out_tb, max_count_tb, zero_tb);
20
21  integer error_count, correct_count;
22
23  initial begin
24    clk_tb = 0;
25    forever begin
26      #2 clk_tb = ~clk_tb;
27      obj1.clk_cv = clk_tb;
28    end
29  end
30
31  always @(posedge clk_tb) begin
32    obj1.count_out = count_out_tb; // mirror DUT output
33    obj1.max_count = max_count_tb;
34    obj1.ZERO      = zero_tb;
35  end
36
37  initial begin
38    error_count = 0;
39    correct_count = 0;
40    zero_flag_expected = 0;
41    max_count_flag_expected = 0;
42    rst_n_tb = 1;
43    // test_1
44    assert_resrt();
45    // test_2
46    repeat (1000) begin
47      assert(obj1.randomize());
48      rst_n_tb = obj1.rst_n;
49      load_n_tb = obj1.load_n;
50      ce_tb = obj1.ce;
51      up_down_tb = obj1.up_down;
52      data_load_tb = obj1.data_load;
53      golden_model();
54      check_result();
55    end
56    assert_resrt();
57    // test_4
58    repeat (16) begin
59      rst_n_tb = 1;
60      ce_tb = 1;
61      up_down_tb = 1;
62      load_n_tb = 1;
63      golden_model();
64      check_result();
65    end
66    repeat (17) begin
67      rst_n_tb = 1;
68      ce_tb = 1;
69      up_down_tb = 0;
70      load_n_tb = 1;
71      golden_model();
72      check_result();
73    end
74    //test_3
75    assert_resrt();
76
77    $display ("correct counter = %d , error counter = %d ", correct_count, error_count);
78    $stop;
79  end
80
81  task check_result();
82    @(negedge clk_tb)
83    if (out_expected == count_out_tb && zero_flag_expected == zero_tb && max_count_flag_expected == max_count_tb) begin
84      $display ("test passes");
85      correct_count = correct_count + 1;
86    end
87    else begin
88      $display ("test fail ");
89      error_count = error_count + 1;
90    end
91  endtask
92
93  task golden_model();
94    zero_flag_expected = 0;
95    max_count_flag_expected = 0;
96    if (!rst_n_tb) out_expected = 0;
97    else begin
98      if (load_n_tb == 0) begin
99        out_expected = data_load_tb;
100     end
101     else if (ce_tb) begin
102       if (up_down_tb) out_expected = out_expected + 1;
103       else out_expected = out_expected - 1;
104     end
105   end
106   if (out_expected == 15) max_count_flag_expected = 1;
107   if (out_expected == 0) zero_flag_expected = 1;
108 endtask
109
110 task assert_resrt();
111   rst_n_tb = 0;
112   golden_model();
113   check_result();
114 endtask
115
116
117
118
119
120 endmodule
```

## 2. Package code

```
 1 package counter_package;
 2     parameter WIDTH = 4 ;
 3     class counter_class;
 4         rand logic load_n;
 5         rand logic rst_n;
 6         rand logic up_down;
 7         rand logic ce;
 8         rand logic [3:0] data_load ;
 9         bit clk_cv ;
10         bit [WIDTH] count_out ;
11         bit max_count ;
12         bit ZERO ;
13
14         constraint rst_n_dist {
15             rst_n dist {1:/95 , 0:/5} ;
16         }
17
18         constraint load_n_dist {
19             load_n dist {1:/70 , 0 :/30} ;
20         }
21
22         constraint ce_dist {
23             ce dist {1:/70 , 0 :/30} ;
24         }
25
26         constraint up_down_dist {
27             up_down dist {1:/70 , 0 :/30} ;
28         }
29
30         covergroup covcode @ (posedge clk_cv);
31             load_data_cv : coverpoint data_load iff (!load_n && rst_n) ;
32
33             count_out_cv_1 : coverpoint count_out iff (rst_n && ce && up_down) ;
34
35             count_out_cv_2 : coverpoint count_out iff (rst_n && ce && up_down) {
36                 bins overflow1 = ((1 << WIDTH) - 1 => 0 ) ;
37             }
38
39             count_out_cv_3 : coverpoint count_out iff (rst_n && ce && !up_down) ;
40
41             count_out_cv_4 : coverpoint count_out iff (rst_n && ce && !up_down) {
42                 bins overflow2 = ( 0 => (1 << WIDTH) - 1 ) ;
43             }
44
45             count_out_cv_5 : coverpoint count_out {
46                 bins full_count = (0 => 1 => 2 => 3 => 4 => 5 => 6 => 7 => 8 => 9
47                               => 10 => 11 => 12 => 13 => 14 => 15);
48             }
49
50             count_out_cv_6 : coverpoint count_out {
51                 bins full_down = (15 => 14 => 13 => 12 => 11 => 10 => 9 => 8 => 7
52                               => 6 => 5 => 4 => 3 => 2 => 1 => 0);
53             }
54
55             max_count_cv : coverpoint max_count ;
56
57             zero_cv : coverpoint ZERO ;
58
59         endgroup
60
61         function new ();
62             covcode = new () ;
63         endfunction
64
65     endclass
66 endpackage
```

### 3. Design code



```
1 //////////////////////////////////////////////////////////////////
2 // Author: Kareem Waseem
3 // Course: Digital Verification using SV & UVM
4 //
5 // Description: Counter Design
6 //
7 //////////////////////////////////////////////////////////////////
8 module counter (clk ,rst_n, load_n, up_down, ce, data_load, count_out, max_count, zero);
9 parameter WIDTH = 4;
10 input clk;
11 input rst_n;
12 input load_n;
13 input up_down;
14 input ce;
15 input [WIDTH-1:0] data_load;
16 output reg [WIDTH-1:0] count_out;
17 output max_count;
18 output zero;
19
20 always @(posedge clk) begin
21     if (!rst_n)
22         count_out <= 0;
23     else if (!load_n)
24         count_out <= data_load;
25     else if (ce)
26         if (up_down)
27             count_out <= count_out + 1;
28         else
29             count_out <= count_out - 1;
30     end
31
32 assign max_count = (count_out == {WIDTH{1'b1}})? 1:0;
33 assign zero = (count_out == 0)? 1:0;
34
35 endmodule
```

### 4. Snippet to your verification plan document

|   | A<br>Label | B<br>Design Requirement Description                                                                                                                                 | C<br>Stimulus Generation                                                                                                           | D<br>Functional Coverage                                                                        | E<br>Functionality Check                                      |
|---|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|---------------------------------------------------------------|
| 1 | TEST_1     | When the reset is asserted by task <b>assert_reset</b> , the output value should be low                                                                             | Directed at the start of the simulation, then randomized with constraint that drive the reset to be most of the simulation off     |                                                                                                 | A checker in the testbench to make sure the output is correct |
| 2 | TEST_2     | when the <b>load_n</b> is low and reset is deasserted , the output should take the value of <b>data_load</b> input                                                  | Randomized under constraints on the <b>load</b> signal to be off 70% of simulation                                                 | cover all values of <b>load_n</b> input signal.                                                 | A checker in the testbench to make sure the output is correct |
| 3 | TEST_3     | when the <b>load_n</b> is high & <b>ce</b> is high , the output should increment when <b>up_down</b> signal is high and decrement when <b>up_down</b> signal is low | Randomized under constraints on the <b>ce</b> signal to be on 70% of simulation & <b>up_down</b> signal to be on 70% of simulation | cover all values of <b>ce</b> input signal.<br>cover all values of <b>up_down</b> input signal. | A checker in the testbench to make sure the output is correct |
| 4 | TEST_3     | When the reset is asserted, the output value should be low                                                                                                          | Directed at the end of the simulation                                                                                              |                                                                                                 | A checker in the testbench to make sure the output is correct |

## 5. Do file

```
1 vlib work
2 vlog counter.v package.svh TESTBENCH.svh +cover -covercells
3 vsim -voptargs=+acc work.counter_tb -cover
4 add wave *
5 coverage save counter.ucdb -onexit -du counter
6 run -all
```

## 6. Code Coverage report snippets

```
# Coverage Report by instance with details
#
# =====
# === Instance: /\ALU_tb#DUT
# === Design Unit: work.alu_seq
# =====
# Branch Coverage:
#   Enabled Coverage      Bins    Hits    Misses  Coverage
#   -----      -----  -----  -----
#   Branches          6       6       0     100%
#
# =====Branch Details=====
#
# Branch Coverage for instance /\ALU_tb#DUT
#
#   Line      Item            Count    Source
#   ----      ----  -----
#   File alu.svh
#   -----IF Branch-----
#   9           1            29935  Count coming in to IF
#   9           1                  2  if (rst)
#
#   11           1            29933  else
#
# Branch totals: 2 hits of 2 branches = 100.00%
#
#   -----CASE Branch-----
#   12           1            29933  Count coming in to CASE
#   13           1                  7509  ADD: out <= operand1 + operand2;
#
#   14           1                  7515  SUB: out <= operand1 - operand2;
#
#   15           1                  7464  MULT:out <= operand1 * operand2;
#
#   16           1                  7445  DIV: out <= operand1 / operand2;
#
# Branch totals: 4 hits of 4 branches = 100.00%
```

```

#
# Toggle Coverage:
#   Enabled Coverage      Bins    Hits    Misses Coverage
#   -----      ----  -----  -----
#   Toggles          56      56      0  100.00%
#
# =====Toggle Details=====
#
# Toggle Coverage for instance /\ALU_tb#DUT --
#
#           Node  1H->0L  0L->1H          "Coverage"
#   -----
#   clk          1      1          100.00
#   opcode       ENUM type  Value  Count
#               ADD      1  100.00
#               SUB      2  100.00
#               MULT     1  100.00
#               DIV      1  100.00
#   operand1[7-0] 1      1          100.00
#   operand2[7-0] 1      1          100.00
#   out[7-0]      1      1          100.00
#   rst          1      1          100.00
#
# Total Node Count = 30
# Toggled Node Count = 30
# Untoggled Node Count = 0
#
# Toggle Coverage = 100.00% (56 of 56 bins)
#
#
# Total Coverage By Instance (filtered view): 100%
#
# End time: 20:22:34 on Sep 09, 2025, Elapsed time: 0:00:00
# Errors: 0, Warnings: 0


| Covergroup                                  | Metric  | Goal | Bins | Status  |
|---------------------------------------------|---------|------|------|---------|
| TYPE /counter_package/counter_class/covcode | 100.00% | 100  | -    | Covered |
| covered/total bins:                         | 56      | 56   | -    |         |
| missing/total bins:                         | 0       | 56   | -    |         |
| % Hit:                                      | 100.00% | 100  | -    |         |
| Coverpoint load_data_cv                     | 100.00% | 100  | -    | Covered |
| covered/total bins:                         | 16      | 16   | -    |         |
| missing/total bins:                         | 0       | 16   | -    |         |
| % Hit:                                      | 100.00% | 100  | -    |         |
| Coverpoint count_out_cv_1                   | 100.00% | 100  | -    | Covered |
| covered/total bins:                         | 16      | 16   | -    |         |
| missing/total bins:                         | 0       | 16   | -    |         |
| % Hit:                                      | 100.00% | 100  | -    |         |
| Coverpoint count_out_cv_2                   | 100.00% | 100  | -    | Covered |
| covered/total bins:                         | 1       | 1    | -    |         |
| missing/total bins:                         | 0       | 1    | -    |         |
| % Hit:                                      | 100.00% | 100  | -    |         |
| Coverpoint count_out_cv_3                   | 100.00% | 100  | -    | Covered |
| covered/total bins:                         | 16      | 16   | -    |         |
| missing/total bins:                         | 0       | 16   | -    |         |
| % Hit:                                      | 100.00% | 100  | -    |         |
| Coverpoint count_out_cv_4                   | 100.00% | 100  | -    | Covered |
| covered/total bins:                         | 1       | 1    | -    |         |
| missing/total bins:                         | 0       | 1    | -    |         |
| % Hit:                                      | 100.00% | 100  | -    |         |
| Coverpoint count_out_cv_5                   | 100.00% | 100  | -    | Covered |
| covered/total bins:                         | 1       | 1    | -    |         |
| missing/total bins:                         | 0       | 1    | -    |         |
| % Hit:                                      | 100.00% | 100  | -    |         |
| Coverpoint count_out_cv_6                   | 100.00% | 100  | -    | Covered |
| covered/total bins:                         | 1       | 1    | -    |         |
| missing/total bins:                         | 0       | 1    | -    |         |
| % Hit:                                      | 100.00% | 100  | -    |         |
| Coverpoint max_count_cv                     | 100.00% | 100  | -    | Covered |
| covered/total bins:                         | 2       | 2    | -    |         |
| missing/total bins:                         | 0       | 2    | -    |         |
| % Hit:                                      | 100.00% | 100  | -    |         |


```

|                                                                     |         |     |   |         |
|---------------------------------------------------------------------|---------|-----|---|---------|
| <u>Coverpoint zero_cv</u>                                           | 100.00% | 100 | - | Covered |
| covered/total bins:                                                 | 2       | 2   | - |         |
| missing/total bins:                                                 | 0       | 2   | - |         |
| % Hit:                                                              | 100.00% | 100 | - |         |
| <u>Covergroup instance \counter_package::counter_class::covcode</u> | 100.00% | 100 | - | Covered |
| covered/total bins:                                                 | 56      | 56  | - |         |
| missing/total bins:                                                 | 0       | 56  | - |         |
| % Hit:                                                              | 100.00% | 100 | - |         |
| <u>Coverpoint load_data_cv</u>                                      | 100.00% | 100 | - | Covered |
| covered/total bins:                                                 | 16      | 16  | - |         |
| missing/total bins:                                                 | 0       | 16  | - |         |
| % Hit:                                                              | 100.00% | 100 | - |         |
| bin auto[0]                                                         | 21      | 1   | - | Covered |
| bin auto[1]                                                         | 22      | 1   | - | Covered |
| bin auto[2]                                                         | 16      | 1   | - | Covered |
| bin auto[3]                                                         | 12      | 1   | - | Covered |
| bin auto[4]                                                         | 20      | 1   | - | Covered |
| bin auto[5]                                                         | 20      | 1   | - | Covered |
| bin auto[6]                                                         | 14      | 1   | - | Covered |
| bin auto[7]                                                         | 16      | 1   | - | Covered |
| bin auto[8]                                                         | 22      | 1   | - | Covered |
| bin auto[9]                                                         | 15      | 1   | - | Covered |
| bin auto[10]                                                        | 22      | 1   | - | Covered |
| bin auto[11]                                                        | 18      | 1   | - | Covered |
| bin auto[12]                                                        | 26      | 1   | - | Covered |
| bin auto[13]                                                        | 20      | 1   | - | Covered |
| bin auto[14]                                                        | 15      | 1   | - | Covered |
| bin auto[15]                                                        | 19      | 1   | - | Covered |
| <u>Coverpoint count_out_cv_1</u>                                    | 100.00% | 100 | - | Covered |
| <u>Coverpoint count_out_cv_1</u>                                    | 100.00% | 100 | - | Covered |
| covered/total bins:                                                 | 16      | 16  | - |         |
| missing/total bins:                                                 | 0       | 16  | - |         |
| % Hit:                                                              | 100.00% | 100 | - |         |
| bin auto[0]                                                         | 60      | 1   | - | Covered |
| bin auto[1]                                                         | 44      | 1   | - | Covered |
| bin auto[2]                                                         | 20      | 1   | - | Covered |
| bin auto[3]                                                         | 23      | 1   | - | Covered |
| bin auto[4]                                                         | 23      | 1   | - | Covered |
| bin auto[5]                                                         | 29      | 1   | - | Covered |
| bin auto[6]                                                         | 23      | 1   | - | Covered |
| bin auto[7]                                                         | 30      | 1   | - | Covered |
| bin auto[8]                                                         | 25      | 1   | - | Covered |
| bin auto[9]                                                         | 26      | 1   | - | Covered |
| bin auto[10]                                                        | 35      | 1   | - | Covered |
| bin auto[11]                                                        | 22      | 1   | - | Covered |
| bin auto[12]                                                        | 28      | 1   | - | Covered |
| bin auto[13]                                                        | 33      | 1   | - | Covered |
| bin auto[14]                                                        | 24      | 1   | - | Covered |
| bin auto[15]                                                        | 27      | 1   | - | Covered |
| <u>Coverpoint count_out_cv_2</u>                                    | 100.00% | 100 | - | Covered |
| covered/total bins:                                                 | 1       | 1   | - |         |
| missing/total bins:                                                 | 0       | 1   | - |         |
| % Hit:                                                              | 100.00% | 100 | - |         |
| bin overflow1                                                       | 6       | 1   | - | Covered |

|                                  |         |     |   |         |
|----------------------------------|---------|-----|---|---------|
| <u>Coverpoint</u> count_out_cv_3 | 100.00% | 100 | - | Covered |
| covered/total bins:              | 16      | 16  | - |         |
| missing/total bins:              | 0       | 16  | - |         |
| % Hit:                           | 100.00% | 100 | - |         |
| bin auto[0]                      | 27      | 1   | - | Covered |
| bin auto[1]                      | 18      | 1   | - | Covered |
| bin auto[2]                      | 14      | 1   | - | Covered |
| bin auto[3]                      | 1       | 1   | - | Covered |
| bin auto[4]                      | 12      | 1   | - | Covered |
| bin auto[5]                      | 12      | 1   | - | Covered |
| bin auto[6]                      | 7       | 1   | - | Covered |
| bin auto[7]                      | 6       | 1   | - | Covered |
| bin auto[8]                      | 11      | 1   | - | Covered |
| bin auto[9]                      | 7       | 1   | - | Covered |
| bin auto[10]                     | 13      | 1   | - | Covered |
| bin auto[11]                     | 13      | 1   | - | Covered |
| bin auto[12]                     | 12      | 1   | - | Covered |
| bin auto[13]                     | 11      | 1   | - | Covered |
| bin auto[14]                     | 11      | 1   | - | Covered |
| bin auto[15]                     | 22      | 1   | - | Covered |
| <u>Coverpoint</u> count_out_cv_4 | 100.00% | 100 | - | Covered |
| covered/total bins:              | 1       | 1   | - |         |
| missing/total bins:              | 0       | 1   | - |         |
| % Hit:                           | 100.00% | 100 | - |         |
| bin overflow2                    | 4       | 1   | - | Covered |
| <u>Coverpoint</u> count_out_cv_5 | 100.00% | 100 | - | Covered |
| covered/total bins:              | 1       | 1   | - |         |
| missing/total bins:              | 0       | 1   | - |         |
| % Hit:                           | 100.00% | 100 | - |         |
| bin full_count                   | 1       | 1   | - | Covered |
| <u>Coverpoint</u> count_out_cv_6 | 100.00% | 100 | - | Covered |
| covered/total bins:              | 1       | 1   | - |         |
| missing/total bins:              | 0       | 1   | - |         |
| % Hit:                           | 100.00% | 100 | - |         |
| bin full_down                    | 1       | 1   | - | Covered |
| <u>Coverpoint</u> count_out_cv_4 | 100.00% | 100 | - | Covered |
| covered/total bins:              | 1       | 1   | - |         |
| missing/total bins:              | 0       | 1   | - |         |
| % Hit:                           | 100.00% | 100 | - |         |
| bin overflow2                    | 4       | 1   | - | Covered |
| <u>Coverpoint</u> count_out_cv_5 | 100.00% | 100 | - | Covered |
| covered/total bins:              | 1       | 1   | - |         |
| missing/total bins:              | 0       | 1   | - |         |
| % Hit:                           | 100.00% | 100 | - |         |
| bin full_count                   | 1       | 1   | - | Covered |
| <u>Coverpoint</u> count_out_cv_6 | 100.00% | 100 | - | Covered |
| covered/total bins:              | 1       | 1   | - |         |
| missing/total bins:              | 0       | 1   | - |         |
| % Hit:                           | 100.00% | 100 | - |         |
| bin full_down                    | 1       | 1   | - | Covered |
| <u>Coverpoint</u> max_count_cv   | 100.00% | 100 | - | Covered |
| covered/total bins:              | 2       | 2   | - |         |
| missing/total bins:              | 0       | 2   | - |         |
| % Hit:                           | 100.00% | 100 | - |         |
| bin auto[0]                      | 959     | 1   | - | Covered |
| bin auto[1]                      | 77      | 1   | - | Covered |
| <u>Coverpoint</u> zero_cv        | 100.00% | 100 | - | Covered |
| covered/total bins:              | 2       | 2   | - |         |
| missing/total bins:              | 0       | 2   | - |         |
| % Hit:                           | 100.00% | 100 | - |         |
| bin auto[0]                      | 910     | 1   | - | Covered |
| bin auto[1]                      | 126     | 1   | - | Covered |

TOTAL COVERGROUP COVERAGE: 100.00% COVERGROUP TYPES: 1

Total Coverage By Instance (filtered view): 100.00%

## 7. Functional Coverage report snippets

```

# =====
# === Instance: /\counter_tb#DUT
# === Design Unit: work.counter
# =====
# Branch Coverage:
#   Enabled Coverage      Bins    Hits    Misses  Coverage
#   -----      -----  -----  -----
#   Branches          10      10      0  100.00%
#
# =====Branch Details=====
#
# Branch Coverage for instance /\counter_tb#DUT
#
#   Line      Item      Count      Source
#   ---      ---      -----
#   File counter.v
#   -----IF Branch-----
#   21                      1036  Count coming in to IF
#   21          1            51    if (!rst_n)
#
#   23          1            298   else if (!load_n)
#
#   25          1            495   else if (ce)
#
#                           192   All False Count
# Branch totals: 4 hits of 4 branches = 100.00%
#
#   -----IF Branch-----
#   26                      495   Count coming in to IF
#   26          1            337   if (up_down)
#
#   28          1            158   else
#
# Branch totals: 2 hits of 2 branches = 100.00%
#
#   -----IF Branch-----
#   26          1            495   Count coming in to IF
#   26          1            337   if (up_down)
#
#   28          1            158   else
#
# Branch totals: 2 hits of 2 branches = 100.00%
#
#   -----IF Branch-----
#   32                      819   Count coming in to IF
#   32          1            58    assign max_count = (count_out == {WIDTH{1'b1}})? 1:0;
#
#   32          2            761   assign max_count = (count_out == {WIDTH{1'b1}})? 1:0;
#
# Branch totals: 2 hits of 2 branches = 100.00%
#
#   -----IF Branch-----
#   33                      819   Count coming in to IF
#   33          1            95    assign zero = (count_out == 0)? 1:0;
#
#   33          2            724   assign zero = (count_out == 0)? 1:0;
#
# Branch totals: 2 hits of 2 branches = 100.00%
#
#
# Condition Coverage:
#   Enabled Coverage      Bins    Covered    Misses  Coverage
#   -----      -----  -----  -----
#   Conditions          2        2        0  100.00%

```

```

#-----#
# Enabled Coverage           Bins   Covered    Misses  Coverage
#-----#
# Conditions                  2       2        0   100.00%
#
# =====Condition Details=====
#
# Condition Coverage for instance /\counter_tb#DUT --
#
# File counter.v
# -----Focused Condition View-----
# Line      32 Item     1  (count_out == {4{{1}}})
# Condition totals: 1 of 1 input term covered = 100.00%
#
#          Input Term   Covered  Reason for no coverage  Hint
#-----#
#  (count_out == {4{{1}}})      Y
#
# Rows:   Hits  FEC Target          Non-masking condition(s)
#-----#
# Row  1:      1  (count_out == {4{{1}}})_0  -
# Row  2:      1  (count_out == {4{{1}}})_1  -
#
# -----Focused Condition View-----
# Line      33 Item     1  (count_out == 0)
# Condition totals: 1 of 1 input term covered = 100.00%
#
#          Input Term   Covered  Reason for no coverage  Hint
#-----#
#  (count_out == 0)      Y
#
# Rows:   Hits  FEC Target          Non-masking condition(s)
#-----#
# Row  1:      1  (count_out == 0)_0  -
# Row  2:      1  (count_out == 0)_1  -
#
#
# Toggle Coverage:
#   Enabled Coverage           Bins   Hits    Misses  Coverage
#-----#
#   Toggles                      30      30        0   100.00%
#
# =====Toggle Details=====
#
# Toggle Coverage for instance /\counter_tb#DUT --
#
#          Node    1H->0L    0L->1H  "Coverage"
#-----#
#      ce            1        1   100.00
#      clk           1        1   100.00
#      count_out[3-0] 1        1   100.00
#      data_load[0-3] 1        1   100.00
#      load_n         1        1   100.00
#      max_count      1        1   100.00
#      rst_n          1        1   100.00
#      up_down         1        1   100.00
#      zero            1        1   100.00
#
# Total Node Count      =      15
# Toggled Node Count    =      15
# Untoggled Node Count =      0
#
# Toggle Coverage      =      100.00% (30 of 30 bins)
#
#
# Total Coverage By Instance (filtered view): 100.00%
#
# End time: 20:40:10 on Sep 09,2025, Elapsed time: 0:00:00
# Errors: 0, Warnings: 0

```

## 8. Clear and neat QuestaSim waveform snippets showing the functionality of the design



P3)

### 1. Testbench code



The screenshot shows a terminal window with a dark background and light-colored text. At the top left are three small colored circles (red, yellow, green). The terminal displays a Verilog testbench script for an ALSU module. The code includes declarations for various registers and wires, instantiation of the DUT, and an initial block for clock generation.

```
import ALSU_package::*;

module ALSU_tb ();
    reg clk_tb ;
    reg rst_tb ;
    reg signed [2:0] A_tb ;
    reg signed [2:0] B_tb ;
    reg signed [1:0] cin_tb ;
    reg serial_in_tb ;
    reg red_op_A_tb ;
    reg red_op_B_tb ;
    opcode_t opcode_tb;
    reg bypass_A_tb ;
    reg bypass_B_tb ;
    reg direction_tb;
    reg invalid ;

    reg signed [5:0] out_expected ;
    reg [16] leds_expected ;

    wire [15:0] leds_tb ;
    wire signed [5:0] out_tb ;

    ALSU_class obj1 = new ;

    ALSU #( .INPUT_PRIORITY("A"), .FULL_ADDER("ON") ) DUT (A_tb, B_tb, cin_tb,
                                                       serial_in_tb,
                                                       red_op_A_tb, red_op_B_tb,
                                                       opcode_tb, bypass_A_tb,
                                                       bypass_B_tb, clk_tb, rst_tb,
                                                       direction_tb, leds_tb, out_tb);

    integer error_count , correct_count ;

    initial begin
        clk_tb = 0;
        forever begin
            #2 clk_tb    = ~clk_tb;
            obj1.clk_cv = clk_tb ;
        end
    end
end
```

```

initial begin
    rst_tb = 0 ;
    error_count = 0 ;
    correct_count = 0 ;
    assert_reset () ;
    obj1.OPCODE_array.constraint_mode (0) ;
repeat (20000) begin
    assert (obj1.randomize())
    rst_tb      = obj1.rst      ;
    A_tb       = obj1.A       ;
    B_tb       = obj1.B       ;
    cin_tb     = obj1.cin     ;
    serial_in_tb = obj1.serial_in ;
    red_op_A_tb = obj1.red_op_A ;
    red_op_B_tb = obj1.red_op_B ;
    bypass_A_tb = obj1.bypass_A ;
    bypass_B_tb = obj1.bypass_B ;
    direction_tb = obj1.direction ;
    opcode_tb   = obj1.opcode   ;
    obj1.sampling_order() ;
    $display ("current opcode_tb is %d and time is %t" , opcode_tb, $time ) ;
    obj1.printing() ;
    golden_model () ;
    check_result () ;
    golden_model () ;
end
obj1.constraint_mode (0) ;
rst_tb = 0 ;
bypass_A_tb = 0 ;
bypass_B_tb = 0 ;
red_op_A_tb = 0 ;
red_op_B_tb = 0 ;
obj1.OPCODE_array.constraint_mode (1) ;
repeat (10000) begin
    assert (obj1.randomize())
    A_tb      = obj1.A      ;
    B_tb      = obj1.B      ;
    cin_tb    = obj1.cin    ;
    serial_in_tb = obj1.serial_in ;
    direction_tb = obj1.direction ;
    obj1.rst = 0 ;
    obj1.bypass_A = 0 ;
    obj1.bypass_B = 0 ;
    obj1.red_op_A = 0 ;
    obj1.red_op_B = 0 ;
    rst_tb = 0 ;
    bypass_A_tb = 0 ;
    bypass_B_tb = 0 ;
    red_op_A_tb = 0 ;
    red_op_B_tb = 0 ;
    for (int i = 0 ; i < 6 ; i = i + 1) begin
        opcode_tb = obj1.opcode_arr[5-i] ;
        obj1.sampling_order() ;
        golden_model () ;
        check_result () ;
        golden_model () ;
        $display ("ittiration number %d" , i ) ;
        $display ("current opcode_tb is %d and time is %t" , opcode_tb, $time ) ;
        obj1.printing() ;
    end
end

```

```
● ● ●

$display("== Starting Directed Transition Coverage Test ==");

// Set all control signals to safe values
rst_tb = 0;
bypass_A_tb = 0;
bypass_B_tb = 0;
red_op_A_tb = 0;
red_op_B_tb = 0;
obj1.rst = 0;
obj1.bypass_A = 0;
obj1.bypass_B = 0;
obj1.red_op_A = 0;
obj1.red_op_B = 0;
assert (obj1.randomize())
    A_tb      = obj1.A      ;
    B_tb      = obj1.B      ;
    cin_tb    = obj1.cin    ;
    serial_in_tb = obj1.serial_in ;
    direction_tb = obj1.direction ;

// Wait for stable clock
@(posedge clk_tb);
@(negedge clk_tb);

// Test each transition explicitly
$display("Testing OR -> XOR transition");
opcode_tb = OR;
obj1.opcode = OR;
@(posedge clk_tb);
obj1.sampling_order();
@(negedge clk_tb);

opcode_tb = XOR;
obj1.opcode = XOR;
@(posedge clk_tb);
obj1.sampling_order();
@(negedge clk_tb);

$display("Testing XOR -> ADD transition");
opcode_tb = ADD;
obj1.opcode = ADD;
@(posedge clk_tb);
obj1.sampling_order();
@(negedge clk_tb);

$display("Testing ADD -> MULT transition");
opcode_tb = MULT;
obj1.opcode = MULT;
@(posedge clk_tb);
obj1.sampling_order();
@(negedge clk_tb);

$display("Testing MULT -> SHIFT transition");
opcode_tb = SHIFT;
obj1.opcode = SHIFT;
@(posedge clk_tb);
obj1.sampling_order();
@(negedge clk_tb);

$display("Testing SHIFT -> ROTATE transition");
opcode_tb = ROTATE;
obj1.opcode = ROTATE;
@(posedge clk_tb);
obj1.sampling_order();
@(negedge clk_tb);

$display("Testing ROTATE -> INVALID_6 transition");
opcode_tb = INVALID_6;
obj1.opcode = INVALID_6;
@(posedge clk_tb);
obj1.sampling_order();
@(negedge clk_tb);

$display("Testing INVALID_6 -> INVALID_7 transition");
opcode_tb = INVALID_7;
obj1.opcode = INVALID_7;
@(posedge clk_tb);
obj1.sampling_order();
@(negedge clk_tb);

assert_reset () ;

$display ("correct counter = %d , error counter = %d " , correct_count , error_count ) ;
$stop ;
end
```

```

task golden_model ();
    leds_expected = 0 ;
    invalid = (opcode_tb == 3'b110) ||
                (opcode_tb == 3'b111) ||
                ((red_op_A_tb || red_op_B_tb) &&
                 (opcode_tb != 3'b000) && (opcode_tb != 3'b001)) ;
    if (rst_tb) begin
        out_expected = 0 ;
    end
    else if (bypass_A_tb) out_expected = A_tb;
    else if (bypass_B_tb) out_expected = B_tb;
    else if (invalid) out_expected = 0;
    else if (opcode_tb == 0) begin
        if (red_op_A_tb) out_expected = |A_tb ;
        else if (red_op_B_tb) out_expected = |B_tb ;
        else out_expected = A_tb | B_tb ;
    end
    else if (opcode_tb == 1) begin
        if (red_op_A_tb) out_expected = ^A_tb ;
        else if (red_op_B_tb) out_expected = ^B_tb ;
        else out_expected = A_tb ^ B_tb ;
    end
    else if (opcode_tb == 2) out_expected = A_tb + B_tb + cin_tb ;
    else if (opcode_tb == 3) out_expected = A_tb * B_tb ;
    else if (opcode_tb == 4) begin
        if (direction_tb) out_expected = {out_expected[4:0] , serial_in_tb } ;
        else out_expected = {serial_in_tb , out_expected[5:1] } ;
    end
    else if (opcode_tb == 5) begin
        if (direction_tb) out_expected = {out_expected[4:0] , out_expected[5] } ;
        else out_expected = {out_expected[0] , out_expected[5:1] } ;
    end
    if (rst_tb) leds_expected = 0 ;
    else begin
        if (invalid)
            leds_expected = ~leds_expected;
        // else leds_expected = 0;
    end
endtask

task check_result ();
    @(negedge clk_tb) ;
    @(negedge clk_tb) ;
    if (out_expected == out_tb && leds_expected == leds_tb) begin
        $display ("test passes") ;
        correct_count = correct_count + 1 ;
    end
    else begin
        $display ("test fail ") ;
        error_count = error_count + 1 ;
    end
endtask

task assert_reset ();
    rst_tb = 1 ;
    out_expected = 0 ;
    leds_expected = 0 ;
    @(negedge clk_tb) ;
    check_result () ;
    rst_tb = 0 ;
endtask
endmodule

```

## 2. Package code

```

package ALSU_package;
parameter MAXPOS = 3;
parameter MAXNEG = -4;
typedef enum logic [2:0] {
    OR, XOR, ADD, MULT, SHIFT, ROTATE, INVALID_6, INVALID_7
} opcode_t;
class ALSU_class;
    rand logic[4:0] t;
    rand logic signed [2:0] A;
    rand logic signed [2:0] B;
    rand logic signed [1:0] cin;
    rand logic serial_in;
    rand logic red_op_A;
    rand logic red_op_B;
    rand logic bypass_A;
    rand logic bypass_B;
    rand logic selection;
    rand opcode_t opcode;
    bit [2:0] last_opcode;
    rand opcode_t [6] opcode_arr;
    bit clk_cv;
    constraint Arithmetic {
        if (opcode == ADD || opcode == MULT) {
            A dist {-4:/25, @:/25, 3:/25, -3:/5, -2:/5, -1:/5, 1:/5, 2:/5};
            B dist {-4:/25, @:/25, 3:/25, -3:/5, -2:/5, -1:/5, 1:/5, 2:/5};
        }
    }
    constraint reduction_A {
        if ((opcode == OR || opcode == XOR) && red_op_A) {
            A dist {3'b001:/25, 3'b010:/25, 3'b100:/25,
                    3'b000:/5, 3'b011:/5, 3'b101:/5, 3'b110:/5, 3'b111:/5};
            B dist {3'b000:/100};
        }
    }
    constraint reduction_B {
        if ((opcode == OR || opcode == XOR) && red_op_B) {
            B dist {3'b001:/25, 3'b010:/25, 3'b100:/25,
                    3'b000:/5, 3'b011:/5, 3'b101:/5, 3'b110:/5, 3'b111:/5};
            A dist {3'b000:/100};
        }
    }
    constraint OPCODE {
        opcode dist { [0:5] :/ 95, [6:7] :/ 5 };
    }
    constraint BYPASS {
        bypass_A dist {0:/95, 1:/5};
        bypass_B dist {0:/95, 1:/5};
    }
    constraint RESET {
        rst dist {0:/99, 1:/1};
    }
    constraint RED_OP {
        if (opcode == OR || opcode == XOR) {
            red_op_A dist {0:/30, 1:/20};
            red_op_B dist {0:/70, 1:/30};
        }
        else {
            red_op_A dist {0:/95, 1:/5};
            red_op_B dist {0:/95, 1:/5};
        }
    }
    constraint OPCODE_array {
        foreach (opcode_arr[])
            opcode_arr[i] inside {OR, XOR, ADD, MULT, SHIFT, ROTATE};
        foreach (opcode_arr[])
            foreach (opcode_arr[])
                if (i != j) opcode_arr[i] != opcode_arr[j];
    }
    covergroup covcode (@posedge clk_cv);
        A_cp : coverpoint A {
            bins A_data_0 = { 0 } ;
            bins A_data_max = {MAXPOS} ;
            bins A_data_min = {MAXNEG} ;
            bins A_data_default = default ;
            bins A_data_walkingones[] = {001,010,100} iff (red_op_A) ;
        }
        B_cp : coverpoint B {
            bins B_data_0 = { 0 } ;
            bins B_data_max = {MAXPOS} ;
            bins B_data_min = {MAXNEG} ;
            bins B_data_default = default ;
            bins B_data_walkingones[] = {001,010,100} iff (!red_op_A && red_op_B) ;
        }
        ALU_CPC : coverpoint opcode {
            bins Bins_shift[] = {SHIFT, ROTATE} ;
            bins Bins_arith[] = {ADD, MULT} ;
            bins Bins_bitwise[] = {OR, XOR} ;
            bins Bins_invalid = {INVALID_6, INVALID_7} ;
            bins trans = (OR => XOR => ADD => MULT => SHIFT => ROTATE) ;
        }
        ALU_TRANS : coverpoint opcode {
            bins trans = (OR => XOR => ADD => MULT => SHIFT => ROTATE => INVALID_6 => INVALID_7) ;
        }
    endgroup
    function new ();
        covcode = new () ;
    endfunction
    function printing ();
        $display ("current opcode_arr is %d , %d , %d , %d , %d , %d and time is %t",
        opcode_arr[], opcode_arr[4], opcode_arr[3], opcode_arr[2], opcode_arr[1], opcode_arr[0], $time)
    ; 
        $display ("current opcode is %d and time is %t", opcode, $time) ;
    endfunction
    function printing2 ();
        $display ("current opcode is %d and time is %t", opcode, $time) ;
    endfunction
    function sampling_order();
        if (!rst || red_op_A || red_op_B)
            covcode.sample();
    endfunction
endclass
endpackage

```

### 3. Design code

```

module ALSU(A, B, cin, serial_in, red_op_A, red_op_B, opcode, bypass_A, bypass_B, clk, rst, direction,
leds, out);
parameter INPUT_PRIORITY = "A";
parameter FULL_ADDER = "ON";
input [1:0] cin;
input [1:0] rst, red_op_A, red_op_B, bypass_A, bypass_B, direction, serial_in;
input signed [1:0] cin;
input signed [2:0] opcode;
input signed [2:0] A, B;
output reg [15:0] leds;
output reg signed [5:0] out;

reg red_op_A_reg, red_op_B_reg, bypass_A_reg, bypass_B_reg, direction_reg, serial_in_reg;
reg signed [1:0] cin_reg;
reg [2:0] opcode_reg;
reg signed [2:0] A_reg, B_reg;

wire invalid_red_op , invalid;

//Invalid handling
assign invalid_red_op = (red_op_A_reg | red_op_B_reg) & (opcode_reg[1] | opcode_reg[2]);
assign invalid_opcode = opcode_reg[1] & opcode_reg[2];
assign invalid = invalid_red_op | invalid_opcode;

//Registering input signals
always @ (posedge clk or posedge rst) begin
    if(rst) begin
        cin_reg <= 0;
        red_op_B_reg <= 0;
        red_op_A_reg <= 0;
        bypass_B_reg <= 0;
        bypass_A_reg <= 0;
        direction_reg <= 0;
        serial_in_reg <= 0;
        opcode_reg <= 0;
        A_reg <= 0;
        B_reg <= 0;
    end else begin
        cin_reg <= cin;
        red_op_B_reg <= red_op_B;
        red_op_A_reg <= red_op_A;
        bypass_B_reg <= bypass_B;
        bypass_A_reg <= bypass_A;
        direction_reg <= direction;
        serial_in_reg <= serial_in;
        opcode_reg <= opcode;
        A_reg <= A;
        B_reg <= B;
    end
end

//leds output blinking
always @ (posedge clk or posedge rst) begin
    if(rst) begin
        leds <= 0;
    end else begin
        if (invalid)
            leds <= ~leds;
        else
            leds <= 0;
    end
end

//ALSU output processing
always @ (posedge clk or posedge rst) begin
    if(rst) begin
        out <= 0;
    end
    else begin
        if (bypass_A_reg && bypass_B_reg)
            out <= (INPUT_PRIORITY == "A")? A_reg: B_reg;
        else if (bypass_A_reg)
            out <= A_reg;
        else if (bypass_B_reg)
            out <= B_reg;
        else if (invalid)
            out <= 0;
        else begin
            case (opcode_reg)
                3'h0: begin
                    if ((red_op_A_reg && red_op_B_reg)
                        || (INPUT_PRIORITY == "A"))
                        out <= A_reg: |B_reg;
                    else if (red_op_A_reg)
                        out <= |A_reg;
                    else if (red_op_B_reg)
                        out <= |B_reg;
                    else
                        out <= A_reg | B_reg;
                end
                3'h1: begin
                    if ((red_op_A_reg && red_op_B_reg)
                        || (INPUT_PRIORITY == "A"))
                        out <= ^A_reg: ^B_reg;
                    else if (red_op_A_reg)
                        out <= ^A_reg;
                    else if (red_op_B_reg)
                        out <= ^B_reg;
                    else
                        out <= A_reg ^ B_reg;
                end
                3'h2: out <= (FULL_ADDER == "ON")? A_reg + B_reg + cin_reg : A_reg + B_reg;
                3'h3: out <= A_Reg * B_Reg ;
                3'h4: begin
                    if (direction_reg)
                        out <= {out[4:0], serial_in_reg};
                    else
                        out <= {serial_in_reg, out[5:1]};
                end
                3'h5: begin
                    if (direction_reg)
                        out <= {out[4:0], out[5]};
                    else
                        out <= {out[0], out[5:1]};
                end
                default : out = 0 ;
            endcase
        end
    end
end
endmodule

```

#### 4. Snippet to your verification plan document

| A       | B                                                                                                                                                                                                                                                                                                                                                                                                                           | C                                                                                                                                                                                                                                                      | D                                                                                                                        | E                                                             |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|
| Label   | Design Requirement Description                                                                                                                                                                                                                                                                                                                                                                                              | Stimulus Generation                                                                                                                                                                                                                                    | Functional Coverage                                                                                                      | Functionality Check                                           |
| TEST_1  | When the reset is asserted by task <code>assert_reset</code> , the output value should be low                                                                                                                                                                                                                                                                                                                               | Directed at the start of the simulation, then randomized with constraint that drive the reset to be most of the time                                                                                                                                   |                                                                                                                          | A checker in the testbench to make sure the output is correct |
| TEST_2  | when the <code>bypass_A</code> is high ,the output take the value of operand A ignoring opcode value,<br>when the <code>bypass_A</code> is low & <code>bypass_A</code> is low , the output take the value of operand A ignoring opcode value when both are high the output take the value of A or B depending on <code>INPUT_PRIORITY</code> value                                                                          | Randomized under constrains on the <code>bypass_A &amp; bypass_B</code> to be off 95% of simulation                                                                                                                                                    | cover all values of <code>bypass_A &amp; bypass_A</code> signals                                                         | A checker in the testbench to make sure the output is correct |
| TEST_3  | when the <code>opcode</code> take the value 6 or 7 (INVALID_OPCODES) the out should be 0 and leds blinking                                                                                                                                                                                                                                                                                                                  | Randomized under constrains on the <code>opcode</code> to take the (value 6 or 7) 70% of simulation                                                                                                                                                    | Ensure that the opcode field is covered when it takes the values 6 and 7                                                 | A checker in the testbench to make sure the output is correct |
| TEST_4  | when <code>red_op_A</code> or <code>red_op_B</code> is high and <code>opcode</code> value is not OR or XOR, the out should be 0 and leds blinking                                                                                                                                                                                                                                                                           | Randomized under constraint on <code>red_op_A &amp; red_op_B</code> when the opcode is not OR or XOR to be off 95% of simulation                                                                                                                       | cover all values of <code>red_op_A &amp; red_op_B</code> signals when the opcode is not OR or XOR                        | A checker in the testbench to make sure the output is correct |
| TEST_5  | when <code>opcode</code> operation is OR if <code>red_op_A</code> is high the output should be reduction OR of operand A , if <code>red_op_A</code> is low & <code>red_op_B</code> is high the output should be reduction OR of operand B when both are high the output depend on <code>INPUT_PRIORITY</code> value If neither reduction control is asserted, the expected output is the bitwise OR of operands A and B     | Randomized under constraint when the opcode is OR on <code>red_op_A</code> to be off 80% of simulation and <code>red_op_B</code> to be off 70% of simulation                                                                                           | cover all values of <code>red_op_A &amp; red_op_B</code> signals when the <code>opcode</code> is OR                      | A checker in the testbench to make sure the output is correct |
| TEST_6  | when <code>opcode</code> operation is XOR if <code>red_op_A</code> is high the output should be reduction XOR of operand A , if <code>red_op_A</code> is low & <code>red_op_B</code> is high the output should be reduction XOR of operand B when both are high the output depend on <code>INPUT_PRIORITY</code> value If neither reduction control is asserted, the expected output is the bitwise XOR of operands A and B | Randomized under constraint when the opcode is XOR on <code>red_op_A</code> to be off 80% of simulation and <code>red_op_B</code> to be off 70% of simulation                                                                                          | cover all values of <code>red_op_A &amp; red_op_B</code> signals when the <code>opcode</code> is OR                      | A checker in the testbench to make sure the output is correct |
| A       | B                                                                                                                                                                                                                                                                                                                                                                                                                           | C                                                                                                                                                                                                                                                      | D                                                                                                                        | E                                                             |
| TEST_7  | when <code>opcode</code> operation is ADD , the <code>output</code> should be equal the summation of <code>operand A &amp; operand B</code> ,if FULL_ADDER is ON we take in consider the CIN value else we ignore it                                                                                                                                                                                                        | Randomized under constraint when the opcode is ADD on <code>operand A &amp; operand B</code> to take value (-4) 25% of simulation , take value (0) 25% of simulation , take value (3) 25% of simulation and take the rest of values 25% of simulation  | cover all values of <code>operand A &amp; operand B</code> inputs when the <code>opcode</code> is ADD                    | A checker in the testbench to make sure the output is correct |
| TEST_8  | when <code>opcode</code> operation is MULT , the <code>output</code> should be equal the multiplication of <code>operand A &amp; operand B</code>                                                                                                                                                                                                                                                                           | Randomized under constraint when the opcode is MULT on <code>operand A &amp; operand B</code> to take value (-4) 25% of simulation , take value (0) 25% of simulation , take value (3) 25% of simulation and take the rest of values 25% of simulation | cover all values of <code>operand A &amp; operand B</code> inputs when the <code>opcode</code> is MULT                   | A checker in the testbench to make sure the output is correct |
| TEST_9  | when <code>opcode</code> operation is SHIFT , the <code>output</code> should be shifted one bit by <code>serial_in</code> input to <code>left</code> if direction signal is <code>high</code> and one bit by <code>serial_in</code> input to <code>right</code> if direction signal is <code>low</code>                                                                                                                     | Randomized the <code>direction</code> signal and <code>serial_in</code> input without any constraints                                                                                                                                                  | cover all values of <code>direction</code> signal and <code>serial_in</code> input when the <code>opcode</code> is SHIFT | A checker in the testbench to make sure the output is correct |
| TEST_10 | when <code>opcode</code> operation is ROTATE , the <code>output</code> should be rotated one bit <code>left</code> if direction signal is <code>high</code> and one bit to <code>right</code> if direction signal is <code>low</code>                                                                                                                                                                                       | Randomized the <code>direction</code> signal without any constraints                                                                                                                                                                                   | cover all values of <code>direction</code> signal and <code>serial_in</code> input when the <code>opcode</code> is SHIFT | A checker in the testbench to make sure the output is correct |
| TEST_11 | When the reset is asserted, the output value should be low                                                                                                                                                                                                                                                                                                                                                                  | Directed at the end of the simulation                                                                                                                                                                                                                  |                                                                                                                          | A checker in the testbench to make sure the output is correct |

#### 5. Do file

```

1 vlib work
2 vlog ALSU.v Package.svh TESTBENCH.svh +cover -covercells
3 vsim -voptargs=+acc work.ALSU_tb -cover
4 add wave *
5 coverage exclude -src ALSU.v -line 112 -code s
6 coverage save ALSU.ucdb -onexit -du ALSU
7 run -all

```

## 6. Code Coverage report snippets

| COVERGROUP COVERAGE:                                     |         |       |       |          |
|----------------------------------------------------------|---------|-------|-------|----------|
| Covergroup                                               | Metric  | Goal  | Bins  | Status   |
| TYPE /ALSU_package/ALSU_class/covcode                    | 100.00% | 100   | -     | Covered  |
| covered/total bins:                                      | 17      | 17    | -     |          |
| missing/total bins:                                      | 0       | 17    | -     |          |
| % Hit:                                                   | 100.00% | 100   | -     |          |
| Coverpoint A_cp                                          | 100.00% | 100   | -     | Covered  |
| covered/total bins:                                      | 4       | 4     | -     |          |
| missing/total bins:                                      | 0       | 4     | -     |          |
| % Hit:                                                   | 100.00% | 100   | -     |          |
| Coverpoint B_cp                                          | 100.00% | 100   | -     | Covered  |
| covered/total bins:                                      | 4       | 4     | -     |          |
| missing/total bins:                                      | 0       | 4     | -     |          |
| % Hit:                                                   | 100.00% | 100   | -     |          |
| Coverpoint ALU_CP                                        | 100.00% | 100   | -     | Covered  |
| covered/total bins:                                      | 8       | 8     | -     |          |
| missing/total bins:                                      | 0       | 8     | -     |          |
| % Hit:                                                   | 100.00% | 100   | -     |          |
| Coverpoint ALU_TRANS                                     | 100.00% | 100   | -     | Covered  |
| covered/total bins:                                      | 1       | 1     | -     |          |
| missing/total bins:                                      | 0       | 1     | -     |          |
| % Hit:                                                   | 100.00% | 100   | -     |          |
| Covergroup instance \/ALSU_package:::ALSU_class::covcode | 100.00% | 100   | -     | Covered  |
| covered/total bins:                                      | 17      | 17    | -     |          |
| missing/total bins:                                      | 0       | 17    | -     |          |
| % Hit:                                                   | 100.00% | 100   | -     |          |
| Coverpoint A_cp                                          | 100.00% | 100   | -     | Covered  |
| covered/total bins:                                      | 4       | 4     | -     |          |
| missing/total bins:                                      | 0       | 4     | -     |          |
| % Hit:                                                   | 100.00% | 100   | -     |          |
| bin A_data_0                                             | 23686   | 1     | -     | Covered  |
| bin A_data_max                                           | 20774   | 1     | -     | Covered  |
| bin A_data_min                                           | 21810   | 1     | -     | Covered  |
| bin A_data_walkingones[1]                                | 666     | 1     | -     | Covered  |
| default bin A_data_default                               | 74979   | -     | -     | Occurred |
| -----                                                    | -----   | ----- | ----- | -----    |
| Coverpoint B_cp                                          | 100.00% | 100   | -     | Covered  |
| covered/total bins:                                      | 4       | 4     | -     |          |
| missing/total bins:                                      | 0       | 4     | -     |          |
| % Hit:                                                   | 100.00% | 100   | -     |          |
| bin B_data_0                                             | 23686   | 1     | -     | Covered  |
| bin B_data_max                                           | 20774   | 1     | -     | Covered  |
| bin B_data_min                                           | 21810   | 1     | -     | Covered  |
| bin B_data_walkingones[1]                                | 126     | 1     | -     | Covered  |
| default bin B_data_default                               | 74979   | -     | -     | Occurred |
| Coverpoint ALU_CP                                        | 100.00% | 100   | -     | Covered  |
| covered/total bins:                                      | 8       | 8     | -     |          |
| missing/total bins:                                      | 0       | 8     | -     |          |
| % Hit:                                                   | 100.00% | 100   | -     |          |
| bin Bins_shift[SHIFT]                                    | 21309   | 1     | -     | Covered  |
| bin Bins_shift[ROTATE]                                   | 21734   | 1     | -     | Covered  |
| bin Bins_arith[ADD]                                      | 21705   | 1     | -     | Covered  |
| bin Bins_arith[MULT]                                     | 20983   | 1     | -     | Covered  |
| bin Bins_bitwise[OR]                                     | 21609   | 1     | -     | Covered  |
| bin Bins_bitwise[XOR]                                    | 21567   | 1     | -     | Covered  |
| bin Bins_invalid                                         | 31105   | 1     | -     | Covered  |
| bin trans                                                | 1       | 1     | -     | Covered  |
| Coverpoint ALU_TRANS                                     | 100.00% | 100   | -     | Covered  |
| covered/total bins:                                      | 1       | 1     | -     |          |
| missing/total bins:                                      | 0       | 1     | -     |          |
| % Hit:                                                   | 100.00% | 100   | -     |          |
| bin trans                                                | 1       | 1     | -     | Covered  |
| TOTAL COVERGROUP COVERAGE: 100.00% COVERGROUP TYPES: 1   |         |       |       |          |
| Total Coverage By Instance (filtered view): 100.00%      |         |       |       |          |

## 7. Functional Coverage report snippets

```

# =====
# === Instance: /\ALSU_tb#DUT
# === Design Unit: work.ALSU
# =====
# Branch Coverage:
#   Enabled Coverage      Bins    Hits    Misses  Coverage
#   -----      -----  -----  -----
#   Branches            32      31       1  96.87%
#
# =====Branch Details=====
#
# Branch Coverage for instance /\ALSU_tb#DUT
#
#   Line      Item          Count      Source
#   ----  -----
#   File ALSU.v
#   -----IF Branch-----
#   25                      159990  Count coming in to IF
#   25          1              362      if(rst) begin
#
#   36          1              159628  end else begin
#
# Branch totals: 2 hits of 2 branches = 100.00%
#
#   -----IF Branch-----
#   52                      160202  Count coming in to IF
#   52          1              546      if(rst) begin
#
#   54          1              159656  end else begin
#
# Branch totals: 2 hits of 2 branches = 100.00%
#
#   -----IF Branch-----
#   55                      159656  Count coming in to IF
#   55          1              4432     if (invalid)
#
#   57          1              155224  else
#
# Branch totals: 2 hits of 2 branches = 100.00%
#
#   -----IF Branch-----
#   68                      147204  Count coming in to IF
#   68          1              80      if (bypass_A_reg && bypass_B_reg)
#
#   70          1              1850    else if (bypass_A_reg)
#
#   72          1              1786    else if (bypass_B_reg)
#
#   74          1              3369    else if (invalid)
#
#   76          1              140119  else begin
#
# Branch totals: 5 hits of 5 branches = 100.00%
#
#   -----CASE Branch-----
#   77                      140119  Count coming in to CASE
#   78          1              23658   3'h0: begin
#
#   88          1              23920   3'h1: begin
#
#   98          1              23869   3'h2: out <= (FULL_ADDER == "ON")? A_reg + B_reg + cin_reg : A_reg + B_reg;
#
#   99          1              24020   3'h3: out <= A_reg * B_reg ;
#
#   100         1              23256   3'h4: begin
#
#   106         1              21396   3'h5: begin
#
#   112         1              ***0*** default : out = 0 ;
#
# Branch totals: 6 hits of 7 branches = 85.71%
#
#   -----IF Branch-----
#   79                      23658   Count coming in to IF
#   79          1              61      if (red_op_A_reg && red_op_B_reg)
#
#   81          1              849     else if (red_op_A_reg)
#
#   83          1              1320    else if (red_op_B_reg)
#
#   85          1              21428   else
#
# Branch totals: 4 hits of 4 branches = 100.00%

```

```

#
# -----IF Branch-----
#
#   89          1      23920    Count coming in to IF
#   89          1       52        if (red_op_A_reg && red_op_B_reg)
#
#   91          1       864        else if (red_op_A_reg)
#
#   93          1      1308        else if (red_op_B_reg)
#
#   95          1      21696        else
#
# Branch totals: 4 hits of 4 branches = 100.00%
#
# -----IF Branch-----
#
#   101         1      23256    Count coming in to IF
#   101         1      11726        if (direction_reg)
#
#   103         1      11530        else
#
# Branch totals: 2 hits of 2 branches = 100.00%
#
# -----IF Branch-----
#
#   107         1      21396    Count coming in to IF
#   107         1      10949        if (direction_reg)
#
#   109         1      10447        else
#
# Branch totals: 2 hits of 2 branches = 100.00%
#
# Condition Coverage:
#   Enabled Coverage      Bins   Covered   Misses   Coverage
#   -----      ----      ----      ----      -----
#   Conditions           6       6       0     100.00%
#
# =====Condition Details=====
#
# Condition Coverage for instance /\ALSU_tb#DUT --
#
#   File ALSU.v
# -----Focused Condition View-----
# Line      68 Item      1  (bypass_A_reg && bypass_B_reg)
# Condition totals: 2 of 2 input terms covered = 100.00%
#
#   Input Term   Covered   Reason for no coverage   Hint
#   -----      -----      -----      -----
#   bypass_A_reg      Y
#   bypass_B_reg      Y
#
#   Rows:      Hits   FEC Target      Non-masking condition(s)
#   -----      -----      -----
#   Row  1:      1  bypass_A_reg_0      -
#   Row  2:      1  bypass_A_reg_1      bypass_B_reg
#   Row  3:      1  bypass_B_reg_0      bypass_A_reg
#   Row  4:      1  bypass_B_reg_1      bypass_A_reg
#
# -----Focused Condition View-----
# Line      79 Item      1  (red_op_A_reg && red_op_B_reg)
# Condition totals: 2 of 2 input terms covered = 100.00%
#
#   Input Term   Covered   Reason for no coverage   Hint
#   -----      -----      -----
#   red_op_A_reg      Y
#   red_op_B_reg      Y
#
#   Rows:      Hits   FEC Target      Non-masking condition(s)
#   -----      -----      -----
#   Row  1:      1  red_op_A_reg_0      -
#   Row  2:      1  red_op_A_reg_1      red_op_B_reg
#   Row  3:      1  red_op_B_reg_0      red_op_A_reg
#   Row  4:      1  red_op_B_reg_1      red_op_A_reg

```

```

#
# ----- Focused Condition View -----
# Line      89 Item    1 (red_op_A_reg && red_op_B_reg)
# Condition totals: 2 of 2 input terms covered = 100.00%
#
#   Input Term  Covered  Reason for no coverage  Hint
#   -----  -----  -----  -----
#   red_op_A_reg      Y
#   red_op_B_reg      Y
#
#   Rows:      Hits  FEC Target          Non-masking condition(s)
#   -----  -----
#   Row  1:      1  red_op_A_reg_0      -
#   Row  2:      1  red_op_A_reg_1      red_op_B_reg
#   Row  3:      1  red_op_B_reg_0      red_op_A_reg
#   Row  4:      1  red_op_B_reg_1      red_op_A_reg
#
#   Expression Coverage:
#   Enabled Coverage          Bins  Covered  Misses  Coverage
#   -----  -----  -----  -----  -----
#   Expressions                  8      8        0  100.00%
#
# ===== Expression Details =====
#
# Expression Coverage for instance /\ALSU_tb#DUT --
#
# File ALSU.v
# ----- Focused Expression View -----
# Line      19 Item    1 ((red_op_A_reg | red_op_B_reg) & (opcode_reg[1] | opcode_reg[2]))
# Expression totals: 4 of 4 input terms covered = 100.00%
#
#   Input Term  Covered  Reason for no coverage  Hint
#   -----  -----  -----  -----
#   red_op_A_reg      Y
#   red_op_B_reg      Y
#   opcode_reg[1]      Y
#   opcode_reg[2]      Y
#
#   Rows:      Hits  FEC Target          Non-masking condition(s)
#   -----  -----
#   Row  1:      1  red_op_A_reg_0  ((opcode_reg[1] | opcode_reg[2]) && ~red_op_B_reg)
#   Row  2:      1  red_op_A_reg_1  ((opcode_reg[1] | opcode_reg[2]) && ~red_op_B_reg)
#   Row  3:      1  red_op_B_reg_0  ((opcode_reg[1] | opcode_reg[2]) && ~red_op_A_reg)
#   Row  4:      1  red_op_B_reg_1  ((opcode_reg[1] | opcode_reg[2]) && ~red_op_A_reg)
#   Row  5:      1  opcode_reg[1]_0  ((red_op_A_reg | red_op_B_reg) && ~opcode_reg[2])
#   Row  6:      1  opcode_reg[1]_1  ((red_op_A_reg | red_op_B_reg) && ~opcode_reg[2])
#   Row  7:      1  opcode_reg[2]_0  ((red_op_A_reg | red_op_B_reg) && ~opcode_reg[1])
#   Row  8:      1  opcode_reg[2]_1  ((red_op_A_reg | red_op_B_reg) && ~opcode_reg[1])
#
# ----- Focused Expression View -----
# Line      20 Item    1 (opcode_reg[1] & opcode_reg[2])
# Expression totals: 2 of 2 input terms covered = 100.00%
#
#   Input Term  Covered  Reason for no coverage  Hint
#   -----  -----  -----  -----
#   opcode_reg[1]      Y
#   opcode_reg[2]      Y
#
#   Rows:      Hits  FEC Target          Non-masking condition(s)
#   -----  -----
#   Row  1:      1  opcode_reg[1]_0  opcode_reg[2]
#   Row  2:      1  opcode_reg[1]_1  opcode_reg[2]
#   Row  3:      1  opcode_reg[2]_0  opcode_reg[1]
#   Row  4:      1  opcode_reg[2]_1  opcode_reg[1]
#
# ----- Focused Expression View -----
# Line      21 Item    1 (invalid_red_op | invalid_opcode)
# Expression totals: 2 of 2 input terms covered = 100.00%
#
#   Input Term  Covered  Reason for no coverage  Hint
#   -----  -----  -----  -----
#   invalid_red_op      Y
#   invalid_opcode      Y
#
#   Rows:      Hits  FEC Target          Non-masking condition(s)
#   -----  -----
#   Row  1:      1  invalid_red_op_0  ~invalid_opcode
#   Row  2:      1  invalid_red_op_1  ~invalid_opcode
#   Row  3:      1  invalid_opcode_0  ~invalid_red_op
#   Row  4:      1  invalid_opcode_1  ~invalid_red_op

```

```

# Statement Coverage:
#   Enabled Coverage      Bins    Hits    Misses  Coverage
#   -----      ----  -----  -----
#   Statements          48     48      0  100.00%
#
# =====Statement Details=====
#
# Statement Coverage for instance /\ALSU_tb#DUT --
#
#   Line      Item      Count    Source
#   ---      ---      ----  -----
# File ALSU.v
#   1           module ALSU(A, B, cin, serial_in, red_op_A, red_op_B, opcode, bypass_A, bypass_B, clk, rst, direction, led
#
#   2           parameter INPUT_PRIORITY = "A";
#
#   3           parameter FULL_ADDER = "ON";
#
#   4           input clk, rst, red_op_A, red_op_B, bypass_A, bypass_B, direction, serial_in;
#
#   5           input signed [1:0] cin ;
#
#   6           input [2:0] opcode;
#
#   7           input signed [2:0] A, B;
#
#   8           output reg [15:0] leds;
#
#   9           output reg signed [5:0] out;
#
#  10
#
#  11           reg red_op_A_reg, red_op_B_reg, bypass_A_reg, bypass_B_reg, direction_reg, serial_in_reg;
#
#  12           reg signed [1:0] cin_reg;
#
#  13           reg [2:0] opcode_reg;
#
#  14           reg signed [2:0] A_reg, B_reg;
#
#  15
#
#  16           wire invalid_red_op , invalid;
#
# =====
#   Enabled Coverage      Bins    Hits    Misses  Coverage
#   -----      ----  -----  -----
#   Toggles          122     122      0  100.00%
#
# =====Toggle Details=====
#
# Toggle Coverage for instance /\ALSU_tb#DUT --
#
#   Node      1H->0L      0L->1H      "Coverage"
#   -----  -----
#   A[0-2]        1         1      100.00
#   A_reg[2-0]     1         1      100.00
#   B[0-2]        1         1      100.00
#   B_reg[2-0]     1         1      100.00
#   bypass_A       1         1      100.00
#   bypass_A_reg   1         1      100.00
#   bypass_B       1         1      100.00
#   bypass_B_reg   1         1      100.00
#   cin[0-1]       1         1      100.00
#   cin_reg[1-0]   1         1      100.00
#   clk            1         1      100.00
#   direction      1         1      100.00
#   direction_reg  1         1      100.00
#   invalid        1         1      100.00
#   invalid_opcode 1         1      100.00
#   invalid_red_op 1         1      100.00
#   leds[15-0]     1         1      100.00
#   opcode[0-2]     1         1      100.00
#   opcode_reg[2-0] 1         1      100.00
#   out[5-0]        1         1      100.00
#   red_op_A        1         1      100.00
#   red_op_A_reg   1         1      100.00
#   red_op_B        1         1      100.00
#   red_op_B_reg   1         1      100.00
#   rst             1         1      100.00
#   serial_in      1         1      100.00
#   serial_in_reg  1         1      100.00
#
# Total Node Count      =      61
# Toggled Node Count    =      61
# Untoggled Node Count =      0
#
# Toggle Coverage      =  100.00% (122 of 122 bins)
#

```

## 8. Clear and neat QuestaSim waveform snippets showing the functionality of the design



```
# test passes
# correct counter =      80010 , error counter =      0
# ** Note: $stop    : TESTBENCH.svh(159)
#   Time: 640088 ns  Iteration: 1  Instance: /ALSU_tb
```

P4)

## 1. Testbench code



```
module memory_tb();
    localparam TESTS = 100 ;
    reg [16] address_array [] ;
    reg [8] data_to_write_array [] ;
    reg [8] data_read_expect_assoc [int] ;
    reg [9] data_read_queue [$] ;
    reg clk_tb ;
    reg write_tb ;
    reg read_tb ;
    reg [8] DATA_in_tb ;
    reg [16] address_tb ;
    wire [9] DATA_out_tb ;
    reg [9] read_data_stored ;

    reg [9] expected_data_out ;

    initial begin
        clk_tb = 0;
        forever begin
            #2 clk_tb = ~clk_tb;
        end
    end

    my_mem DUT (clk_tb , write_tb , read_tb , DATA_in_tb , address_tb , DATA_out_tb ) ;

    int correct_count , error_count ;

    initial begin
        stimulus_gen () ;
        golden_model () ;
        write_tb = 1 ;
        read_tb = 0 ;
        for (int i = 0; i < TESTS; i++) begin
            address_tb = address_array [i] ;
            DATA_in_tb = data_to_write_array [i] ;
            @(negedge clk_tb);
        end
        write_tb = 0 ;
        read_tb = 1 ;
        for (int i = 0; i < TESTS; i++) begin
            address_tb = address_array [i] ;
            check9Bts (data_read_expect_assoc[address_array[i]]) ;
            print_test_result () ;
            data_read_queue.push_back (DATA_out_tb) ;
        end
        $display("read data stored in the queue");
        for (int i = 0; i < TESTS; i++) begin
            read_data_stored = data_read_queue.pop_front() ;
            check9Bts (data_read_expect_assoc[address_array[i]]) ;
            $display("read data with index %d is %b" , i , read_data_stored);
            $display("read data expected with index %d is %b" , i , expected_data_out);
        end
        $display ("correct counter = %d , error counter = %d " , correct_count , error_count ) ;
        $stop ;
    end

    task stimulus_gen ();
        address_array = new[TESTS];
        data_to_write_array = new[TESTS];
        for (int i = 0; i < TESTS; i++) begin
            address_array[i] = $random;
            data_to_write_array[i] = $random;
        end
    endtask

    task golden_model ();
        for (int i = 0; i < TESTS; i++) begin
            data_read_expect_assoc [address_array[i]] = data_to_write_array [i] ;
        end
    endtask

    task check9Bts (reg [8] data_written );
        expected_data_out = {~^data_written , data_written} ;
    endtask

    task print_test_result();
        @(negedge clk_tb);
        if (DATA_out_tb == expected_data_out) begin
            $display ("test passes");
            correct_count = correct_count + 1 ;
        end
        else begin
            $display ("test fail ");
            error_count = error_count + 1 ;
        end
    endtask
endmodule
```

## 2. Design code

```
1  module my_mem(
2    input clk,
3    input write,
4    input read,
5    input [7:0] data_in,
6    input [15:0] address,
7    output reg [8:0] data_out
8  );
9
10 // Declare a 9-bit associative array using the logic data type & the key of int datatype
11 logic [9] mem_array [int] ;
12
13 always @(posedge clk) begin
14   if (write)
15     mem_array[address] = {~^data_in, data_in};
16   else if (read)
17     data_out = mem_array[address];
18 end
19 endmodule
```

3. Report any bugs detected in the design and fix them
  - Change the width of **DATA\_out** from **9 bits** to **8 bits**
4. Snippet to your verification plan document

## 5. Do file



```

1 vlib work
2 vlog DESIGN.svh TESTBENCH.svh +cover -covercells
3 vsim -voptargs=-acc work.memory_tb -cover
4 add wave -position insertpoint \
5 sim:/memory_tb/TESTS \
6 sim:/memory_tb/clk_tb \
7 sim:/memory_tb/write_tb \
8 sim:/memory_tb/read_tb \
9 sim:/memory_tb/DATA_in_tb \
10 sim:/memory_tb/address_tb \
11 sim:/memory_tb/DATA_out_tb \
12 sim:/memory_tb/read_data_stored \
13 sim:/memory_tb/expected_data_out \
14 sim:/memory_tb/correct_count \
15 sim:/memory_tb/error_count
16 coverage save my_mem.ucdb -onexit -du ALSU
17 run -all

```

**Associated array , queue and dynamic array** cannot added to waveform so I exclude them in do file

## 6. Clear and neat QuestaSim waveform snippets showing the functionality of the design







```
# read data with index          22 is 111001111
# read data expected with index      22 is 111001111
# read data with index          23 is 100001010
# read data expected with index      23 is 100001010
# read data with index          24 is 100111100
# read data expected with index      24 is 100111100
# read data with index          25 is 010001010
# read data expected with index      25 is 010001010
# read data with index          26 is 111011000
# read data expected with index      26 is 111011000
# read data with index          27 is 010001001
# read data expected with index      27 is 010001001
# read data with index          28 is 010110110
# read data expected with index      28 is 010110110
# read data with index          29 is 010101110
# read data expected with index      29 is 010101110
# read data with index          30 is 000101010
# read data expected with index      30 is 000101010
# read data with index          31 is 101110001
# read data expected with index      31 is 101110001
# read data with index          32 is 001001111
# read data expected with index      32 is 001001111
# read data with index          33 is 100111010
# read data expected with index      33 is 100111010
# read data with index          34 is 000010101
# read data expected with index      34 is 000010101
# read data with index          35 is 011011001
# read data expected with index      35 is 011011001
# read data with index          36 is 001001100
# read data expected with index      36 is 001001100
# read data with index          37 is 010001111
# read data expected with index      37 is 010001111
# read data with index          38 is 110110111
# read data expected with index      38 is 110110111
# read data with index          39 is 101011100
# read data expected with index      39 is 101011100
# read data with index          40 is 010001001
# read data expected with index      40 is 010001001
# read data with index          41 is 011010000
# read data expected with index      41 is 011010000
# read data with index          42 is 001010001
# read data expected with index      42 is 001010001
# read data with index          43 is 100001100
# read data expected with index      43 is 100001100
```

```
# read data with index          44 is 011001000
# read data expected with index      44 is 011001000
# read data with index          45 is 000111101
# read data expected with index      45 is 000111101
# read data with index          46 is 101111110
# read data expected with index      46 is 101111110
# read data with index          47 is 100111001
# read data expected with index      47 is 100111001
# read data with index          48 is 011010011
# read data expected with index      48 is 011010011
# read data with index          49 is 101111000
# read data expected with index      49 is 101111000
# read data with index          50 is 001001001
# read data expected with index      50 is 001001001
# read data with index          51 is 000101010
# read data expected with index      51 is 000101010
# read data with index          52 is 010000110
# read data expected with index      52 is 010000110
# read data with index          53 is 110011100
# read data expected with index      53 is 110011100
# read data with index          54 is 000100110
# read data expected with index      54 is 000100110
# read data with index          55 is 110100011
# read data expected with index      55 is 110100011
# read data with index          56 is 010110011
# read data expected with index      56 is 010110011
# read data with index          57 is 101000100
# read data expected with index      57 is 101000100
# read data with index          58 is 011001011
# read data expected with index      58 is 011001011
# read data with index          59 is 101011010
# read data expected with index      59 is 101011010
# read data with index          60 is 111101101
# read data expected with index      60 is 111101101
# read data with index          61 is 101100101
# read data expected with index      61 is 101100101
# read data with index          62 is 011011111
# read data expected with index      62 is 011011111
# read data with index          63 is 101000100
# read data expected with index      63 is 101000100
# read data with index          64 is 000101010
# read data expected with index      64 is 000101010
# read data with index          65 is 000001110
# read data expected with index      65 is 000001110
# read data with index          66 is 110011010
# read data expected with index      66 is 110011010
```

```
# read data with index      67 is 111000011
# read data expected with index      67 is 111000011
# read data with index      68 is 101001110
# read data expected with index      68 is 101001110
# read data with index      69 is 100001010
# read data expected with index      69 is 100001010
# read data with index      70 is 000111000
# read data expected with index      70 is 000111000
# read data with index      71 is 110111000
# read data expected with index      71 is 110111000
# read data with index      72 is 110010011
# read data expected with index      72 is 110010011
# read data with index      73 is 101011001
# read data expected with index      73 is 101011001
# read data with index      74 is 101001101
# read data expected with index      74 is 101001101
# read data with index      75 is 001101101
# read data expected with index      75 is 001101101
# read data with index      76 is 111001010
# read data expected with index      76 is 111001010
# read data with index      77 is 110010101
# read data expected with index      77 is 110010101
# read data with index      78 is 000000100
# read data expected with index      78 is 000000100
# read data with index      79 is 101101001
# read data expected with index      79 is 101101001
# read data with index      80 is 110001000
# read data expected with index      80 is 110001000
# read data with index      81 is 100101101
# read data expected with index      81 is 100101101
# read data with index      82 is 100101110
# read data expected with index      82 is 100101110
# read data with index      83 is 000011100
# read data expected with index      83 is 000011100
# read data with index      84 is 000101001
# read data expected with index      84 is 000101001
# read data with index      85 is 010000110
# read data expected with index      85 is 010000110
# read data with index      86 is 000111101
# read data expected with index      86 is 000111101
# read data with index      87 is 001110000
# read data expected with index      87 is 001110000
# read data with index      88 is 010111010
# read data expected with index      88 is 010111010
# read data with index      89 is 111111010
# read data expected with index      89 is 111111010
```

```
# read data expected with index      89 is 111111010
# read data with index      90 is 000011010
# read data expected with index      90 is 000011010
# read data with index      91 is 000110111
# read data expected with index      91 is 000110111
# read data with index      92 is 111000000
# read data expected with index      92 is 111000000
# read data with index      93 is 010110110
# read data expected with index      93 is 010110110
# read data with index      94 is 011011100
# read data expected with index      94 is 011011100
# read data with index      95 is 101111000
# read data expected with index      95 is 101111000
# read data with index      96 is 111011011
# read data expected with index      96 is 111011011
# read data with index      97 is 001111001
# read data expected with index      97 is 001111001
# read data with index      98 is 001100001
# read data expected with index      98 is 001100001
# read data with index      99 is 010100001
# read data expected with index      99 is 010100001
# correct counter =      100 , error counter =      0
# ** Note: $stop    : TESTBENCH.svh(55)
#   Time: 800 ns  Iteration: 1  Instance: /memory_tb
# Break in Module memory_tb at TESTBENCH.svh line 55
```