Nimitt (22110169)

Pratham Sharda (22110203)

## **Toggle Flip Flop**

```
`timescale 1ns / 1ps
// Company:
// Engineer:
//
// Create Date: 30.01.2024 03:16:52
// Design Name:
// Module Name: Tff
// Project Name:
// Target Devices:
// Tool Versions:
// Description:
//
// Dependencies:
//
// Revision:
// Revision 0.01 - File Created
// Additional Comments:
//
module Tff(
  input T,
  input Clk,
  input Reset,
  output reg Q
```

```
);
always @(posedge Clk, negedge Reset)
begin
    begin
    if (!Reset)
        Q <= 0;
else
        begin
    if ( T == 1)
        Q <= -Q;
    else
        Q <= Q;
    end
    end
end
end
endmodule</pre>
```

```
`timescale 1ns / 1ps
// Company:
// Engineer:
//
// Create Date: 30.01.2024 03:29:37
// Design Name:
// Module Name: Tff tb
// Project Name:
// Target Devices:
// Tool Versions:
// Description:
//
// Dependencies:
//
// Revision:
// Revision 0.01 - File Created
// Additional Comments:
```

```
//
module Tff_tb();
   reg T, Reset, Clk;
   wire Q;
   Tff uut(T, Clk, Reset, Q);
   initial
   begin
   Clk = 0;
      forever #5 Clk = ~Clk;
   end
   initial
   begin
   T = 1; Reset = 0;
   #10;
   T = 1; Reset = 1;
   #10;
   $finish();
   end
endmodule
```



## **Asynchronous Counter**

```
`timescale 1ns / 1ps
// Company:
// Engineer:
//
// Create Date: 30.01.2024 03:24:17
// Design Name:
// Module Name: Ascounter
// Project Name:
// Target Devices:
// Tool Versions:
// Description:
//
// Dependencies:
//
// Revision:
```

```
// Revision:
// Revision 0.01 - File Created
// Additional Comments:
//
module Ascounter_tb();
   reg Clk, Reset;
   wire [3:0] OUT;
   Ascounter uut(Clk, Reset, OUT);
   initial
   begin
   Clk = 0;
       forever #5 Clk = ~Clk;
   end
   initial begin
       Reset = 0;
       #10;
       Reset = 1;
       #10;
   $finish();
   end
endmodule
```

Final Simulation Results:



