



## tb\_monostable\_multivibrator.v

/home/itzzinfinity/Cozy Drive/100daysofRTL/day\_040/ZZ MonoStableMV/ZZ MonoStableMV.srcs/sim\_1/new/tb\_monostable\_multivibrator.v

```
1
        timescale 1ns / 1ps
2 🖨
        3 ¦
        // Engineer: Anjan Prasad
4
        // Create Date: 10/31/2024 08:14:07 AM
5
        '// Module Name: tb monostable multivibrator
        6 🛆
7
8 🖨
        module tb monostable multivibrator;
9
10
           reg clk;
                           // Clock signal
11
                           // Reset signal
           req rst;
12
                           // Trigger input
           reg trigger;
13
           wire out;
                            // Output pulse
14
15
           monostable multivibrator UUT (.clk(clk),.rst(rst),.trigger(trigger),.out(out));
16
17
           always #5 clk = ~clk;
18
19 🖨
           initial begin
20
               // Initialize all signals
21
               clk = 0;
22
               rst = 1:
23
               trigger = 0;
24
25
     0
               #20 \text{ rst} = 0;
26
27
               #30 trigger = 1; // Trigger pulse starts at 30ns
28
               #10 trigger = 0; // Stop trigger after 10ns
29
     \circ
30
     \circ
               #100 trigger = 1; // Trigger again at 130ns
31
     \circ
               #10 trigger = 0; // Stop trigger after 10ns
32
33
               #200 trigger = 1; // Trigger again at 340ns
    0
34
               #10 trigger = 0; // Stop trigger after 10ns
35
36
               // End the simulation after sufficient time
37
     0
               #500 $finish;
38 🛆
     \circ
           end
39 🖨
           initial begin
40
               $monitor("Time = %0t | Reset = %b | Trigger = %b | Output = %b", $time, rst, trigger, out);
    \circ
41 🛆
           end
42
     0
43 🛆
        endmodule
44
45
     \circ
     0
```

```
/home/itzzinfinity/Cozy Drive/100daysofRTL/day 040/ZZ MonoStableMV/ZZ MonoStableMV.srcs/sources 1/new/monostable multivibrator.v
// Engineer: Anjan Prasad
  // Create Date: 10/31/2024 08:08:42 AM
   // Module Name: monostable multivibrator
    8
    module monostable multivibrator(
10
       input clk, // Clock signal
                 // Reset signal
11
       input rst,
                     // Trigger input
// Output pulse
12
       input trigger,
13
       output reg out
14 );
15
       reg [31:0] counter; // Counter for pulse duration
16
       req pulse active;
                         // Flag to check if the pulse is active
17
18 🖨
       always @(posedge clk or posedge rst) begin
19 🖨
           if (rst) begin
20
              counter <= 0:
21
              out \leq 0;
22
              pulse active <= 0;
23 🖒
           end
24 🖨
           else if (trigger && !pulse active) begin
25
              pulse active <= 1;
26
              counter <= 0;
27
              out <= 1;
28 🛆
           end
29 🖨
           else if (pulse active) begin
30 🖨
              if (counter == 20) begin
                                     // Duration of the pulse
31
                  pulse active <= 0;
32
                  out \leq 0;
33
              end
34 🖨
              else begin
35
                  counter <= counter + 1;
36 点
              end
37 🖒
           end
38
       end
39 🖒 endmodule
```