## DAY-71 #100DAYSOFRTL

**AIM:---** IMPLEMENTATION OF 4-BIT JOHNSON COUNTER.

**VERILOG CODE:--**

```
1  module johnson_counter( out, reset, clk);
    input clk, reset;
 3
   output [3:0] out;
 5 | reg [3:0] q;
 6
 7 \( \begin{aligned}
            always @(posedge clk)
 8 🖯 begin
10 🖯 if (reset)
11 !
     q=4'd0;
12
     else
13 🖯
       begin
14 !
              q[3]<=q[2];
15 ¦
              q[2]<=q[1];
16 '
              q[1]<=q[0];
17
              q[0] <= (\sim q[3]);
18 🖨
       end
19 🗎 end
20
21
    assign out=q;
22 🖨 endmodule
```

## **TESTBENCH CODE:---**

```
1 omodule johnson_counter_tb();
 2 ¦
     req clk,rst;
 3 ¦
     wire [3:0] out;
 5 !
     johnson_counter dut (.out(out), .rst(rst), .clk(clk));
 6
 7 😓
     always
      #5 clk =~clk;
 8 🖨
 9 ¦
10 pinitial begin
11 |
       rst=1'b1; clk=1'b0;
12
      #20 rst= 1'b0;
13 🖨 end
14
15 🖯
     initial
16 😓
17 ¦
       $monitor( $time, " clk=%b, out= %b, rst=%b", clk,out,rst);
18
        #105 $stop;
19 🖨
     end
20
21 🖨 endmodule
```

## WAVEFORM:----



## SCHEMATIC:-----

