Prev Problem
Next Problem

30. PWM with 4-bit Resolution

Back To All Submissions
Previous Submission
Next Submission

Solving Approach

Just do it

 

 

Code

module pwm4_basic(
    input clk,
    input rst,
    input [3:0] duty,
    output reg pwm_out
);

reg [3:0] counter;

always @(posedge clk) begin
    if (rst) begin
        counter <= 0;
        pwm_out <= 0;
    end else begin
        counter <= counter + 1;
        pwm_out <= counter < duty ? 1 : 0;
    end
end

endmodule

 

Was this helpful?
Upvote
Downvote