前面分别介绍了偶数和奇数分频(即整数分频),接下来本文介绍小数分频。
对于要求相位以及占空比严格的小数分频,建议采用interwetten与威廉的赔率体系 电路实现。 而使用数字电路实现只能保证尽量均匀,在长时间内进行分频 。
在讨论小数分频之前,先问一个问题:设计中是否真的需要50%占空比的时钟
在回答这个问题之前,可以先回顾之前我们写过的RTL设计,可以看一下之前的RTL设计代码中always块是不是大部分都是@(posedge clk)。 对于绝大多数的触发器,其实只需要用到时钟的上升沿触发,很少用到下降沿。 在这种情况下,只要上升沿和时钟频率有关系,什么时候来下降沿不重要! 所以50%的占空比不是必须的 。
因此在小数分频器中我们关注的是如何得到一个尽量均匀的分频信号,而不是得到一个绝对50%占空比的分频信号。
下面以4.5倍的分频(非50%占空比)作为例子介绍,即每9个参考时钟包含2个对称脉冲。 下面是4.5分频的设计步骤。
①:使用复位值为000000001的9位移位寄存器,可以在每个时钟上升沿使移位寄存器循环左移一位。
②:要产生第一个脉冲,必须使在半周期时移动第一位并将第一位与第二位进行或操作。
③:要产生第二个脉冲,第5位和第6位必须在半周期时移动并与原始第6位进行或操作。
注意:所有这些移位都是用来保证输出波形不含毛刺的必要条件。
上面产生的时钟占空比为40%,并且输出的时钟完全不含毛刺。
always@(posedge clk or negedge rst_n)
if(!rst_n)
cnt[9:1] <= 9'b000000001;
else
cnt[9:1] <= cnt[9:1] << 1;
always@(negedge clk or negedge rst_n)
if(!rst_n)begin
count1 <= 1'b0;
count5 <= 1'b0;
count6 <= 1'b0;
end
else begin
count1 <= cnt[1];
count5 <= cnt[5];
count6 <= cnt[6];
end
assign clkout = (cnt[6] | count5 | count6) |
(cnt[0] | cnt[1] |count1);
-
脉冲
+关注
关注
20文章
889浏览量
95621 -
分频器
+关注
关注
43文章
447浏览量
49887 -
时钟
+关注
关注
10文章
1733浏览量
131460 -
RTL
+关注
关注
1文章
385浏览量
59766 -
小数分频
+关注
关注
0文章
7浏览量
6678
发布评论请先 登录
相关推荐
基于FPGA的双模前置小数分频器的设计

FPGA众多分频资料,不容错过
低通滤波器的FPGA设计及仿真
请问AD9361中ADC、DAC采样时钟的可设置的最小分辨率是多少?
FPGA的小数分频器的实现,并行快速FIR滤波器的FPGA实现.pdf
实现任意整数分频的原理与方法讲解
如何使用FPGA进行任意小数分频器的设计

具有小数分频器的CDCM6208 2:8时钟生成器/抖动消除器数据表

CDCM6208V1F具有小数分频器的2:8时钟生成器/抖动消除器数据表

CDCM6208V2G具有小数分频器的2:8时钟发生器/抖动消除器数据表

评论