FREQUENCY DIVIDER

A frequency divider, also called clock divider is a circuit that takes an input signal of a frequency fin. And generates an output signal of a frequency:

![](data:image/png;base64,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)

Integer Clock Dividers: where N is an integer.

N

**EVEN DIVIDER**

The division factor N is an even number (2, 4, 6, 8…).

Simple to implement using toggle flip-flops or counters.

Divide by 2

Divide by 4

Divide by 6

**ODD DIVIDER**

The division factor NNN is an odd number (e.g., 3, 5, 7).

Odd dividers inherently produce asymmetric output waveforms with unequal high and low phases (non-50% duty cycle).

Additional logic is needed for duty cycle correction if symmetry is required.

Divide by 3

Divide by 5

module clk\_div2(input clk, input reset, output reg clk\_out);

always @(posedge clk or posedge reset) begin

if (reset)

clk\_out <= 0;

else

clk\_out <= ~clk\_out; // Toggle every clock cycle

end

endmodule

module clk\_div3(input clk, input reset, output reg clk\_out);

reg [1:0] count;

always @(posedge clk or posedge reset) begin

if (reset) begin

count <= 0;

clk\_out <= 0;

end else if (count == 2) begin

count <= 0;

clk\_out <= ~clk\_out;

end else

count <= count + 1;

end

endmodule

module clk\_div4(input clk, input reset, output reg clk\_out);

reg [1:0] count;

always @(posedge clk or posedge reset) begin

if (reset) begin

count <= 0;

clk\_out <= 0;

end else if (count == 2'b11) begin

count <= 0;

clk\_out <= ~clk\_out;

end else

count <= count + 1;

end

endmodule

module clk\_div5(input clk, input reset, output reg clk\_out);

reg [2:0] count; // 3 bits to count up to 5

always @(posedge clk or posedge reset) begin

if (reset) begin

count <= 0;

clk\_out <= 0;

end else if (count == 4) begin

count <= 0;

clk\_out <= ~clk\_out; // Toggle every 5 cycles

end else

count <= count + 1;

end

endmodule

module clk\_div6(input clk, input reset, output reg clk\_out);

reg [2:0] count; // 3 bits to count up to 6

always @(posedge clk or posedge reset) begin

if (reset) begin

count <= 0;

clk\_out <= 0;

end else if (count == 5) begin

count <= 0;

clk\_out <= ~clk\_out; // Toggle every 6 cycles

end else

count <= count + 1;

end

endmodule