在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
查看: 3458|回复: 3

[原创] verilog实现任意分频比

[复制链接]
发表于 2019-7-13 19:39:11 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

x
偶数分频的话比较好办,只要数上升沿就可以了。但是如果是奇数分频比的话,光数上升沿是不行的,还需要数下降沿
比如
module div_any(clk,rst_n,out);
input clk;
input rst_n;
output reg out;
reg[5:0]count;
parameter N=3;
always@(posedge clk or negedge clk)begin
if(rst_n==0)begin
count<=6'b0;
out<=1'b0;
end
else begin
count<=count+1'b1;
if(count==(N-1))begin
count<=6'b0;
out<=~out;
end
end
end
endmodule
其中的N为分频比,如果上升沿和下降沿同时计数的话,就可以做到奇数和偶数分频。
这里抛砖引玉,我们始终假设输入信号clK的占空比为50%,但是如果输入信号占空比不为50%又该怎么办呢?

发表于 2019-7-17 16:28:45 | 显示全部楼层
只用上升沿就可以实现奇数分频,用两个计数器,分别产生分频输出的1和0,这样分频输出的占空比不是50%哦
 楼主| 发表于 2019-7-18 13:16:45 | 显示全部楼层


G_yesorno 发表于 2019-7-17 16:28
只用上升沿就可以实现奇数分频,用两个计数器,分别产生分频输出的1和0,这样分频输出的占空比不是50%哦 ...


只用计数上升沿就可以实现奇数分频么?请问该怎么实现呢?
发表于 2019-7-19 12:40:11 | 显示全部楼层


peter861021 发表于 2019-7-18 13:16
只用计数上升沿就可以实现奇数分频么?请问该怎么实现呢?


比如3分频:  计数器a 计2个clk上升沿,输出翻转一次; 计数器b 计1个clk上升沿,输出翻转一次。  
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

站长推荐 上一条 /1 下一条


小黑屋| 手机版| 关于我们| 联系我们| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2024-12-28 13:35 , Processed in 0.016443 second(s), 7 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表