标签:pre counter 选择 仿真 VID com input 整数 tput
分频器主要用于提供不同相位和频率的时钟
分频后的时钟频率都小于原始时钟的频率,若没有更高频的主时钟无法得到同步分频时钟;
以获得ƒ/2n的时钟信号为例:一个周期内,占空比50%的原始时钟信号ƒ在高电平与低电平的时间相同、相位相差180°(相反),因此相邻的两个上升沿(或者下降沿)的频率必然是原始时钟的1/2倍。之后通过Counter数n个ƒ/2信号就可以获得ƒ/2n的时钟信号了。
module divider #(parameter NUM_DIV = 8)(
output div_clk,
input clk, rst
);
reg [3:0] cnt;
always @(posedge clk)
begin
if(!rst)
cnt <=0;
else if(cnt==(NUM_DIV/2)-1)
cnt <= 0;
else
cnt <= cnt+1;
end
assign div_clk = (cnt<=NUM_DIV/2-1)?1:0;
endmodule
这种分频器有多种方法实现,其基本原理也是基于多个偶数分频器的组合逻辑实现。
原理1:使用两个周期为2N、相位差为90°的时钟信号来获得周期为N的奇数分频器(N为odd);
原理2:使用一个(N-1)/2和(N+1)/2
原理1:
1.5倍频为每三个参考时钟包含两个对称的脉冲
应为在多路选择端切换开关时两个输入端的延时不相等,多路器的输出不能马上改变,并可能在输出始终上产生毛刺,并且随着参考时钟(ref_clk)频率的增加,出现错误的可能性会越来越大。在仿真时可以正确工作,但是在综合可能出现问题。
根据分频的
标签:pre counter 选择 仿真 VID com input 整数 tput
原文地址:https://www.cnblogs.com/lizhiqing/p/12063863.html