完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
扫一扫,分享给好友
这是代码:
module counter(q,clock,clear); output [3:0] q; input clock,clear; T_FF tff0(q[0],clock,clear); T_FF tff1(q[1],q[0],clear); T_FF tff2(q[2],q[1],clear); T_FF tff3(q[3],q[2],clear); endmodule module T_FF(q,clock,reset); output q; input clock,reset; D_FF d_ff(.q(q),.clk(clock),.clear(reset),.d(~q)); endmodule module D_FF(q,qbar,clear,clk,d); output q,qbar; input clear,clk,d; wire ***ar,s,r,rbar,cbar; assign cbar=~clear; assign ***ar=~(rbar&s); assign s=~(***ar&cbar&~clk); assign r=~(s&~clk&rbar); assign q=~(s&qbar); assign qbar=~(q&cbar&r); endmodule module counterstimulus; reg clock,clear; wire [3:0] q; counter c1(q,clock,clear); initial begin $monitor($time," q=%b,clock=%b,clear=%b",q,clock,clear); end initial begin clear=1'b1; forever #30 clear=~clear; end initial begin clock=1'b0; forever #10 clock=~clock; end endmodule 这是仿真结果: # 0 q=0000,clock=0,clear=1 run run # 10 q=0000,clock=1,clear=1 run run # 20 q=0000,clock=0,clear=1 run run # 30 q=xxx0,clock=1,clear=0 run run # 40 q=xxxx,clock=0,clear=0 run run # 50 q=xxxx,clock=1,clear=0 run run # 60 q=0000,clock=0,clear=1 run run # 70 q=0000,clock=1,clear=1 run run # 80 q=0000,clock=0,clear=1 run run # 90 q=xxx0,clock=1,clear=0 run run # 100 q=xxxx,clock=0,clear=0 run run # 110 q=xxxx,clock=1,clear=0 run q为什么会出现xxxx? |
|
相关推荐
6个回答
|
|
主从JK触发器设计同步计数器:http://wenku.baidu.com/view/b1547f91195f312b3169a595.html |
|
|
|
z00 发表于 2014-4-15 19:51 谢谢您的解答。 |
|
|
|
|
|
|
|
本帖最后由 youzizhile 于 2014-4-16 17:32 编辑
module counter(q,clock,clear); 实现的是计数器,clear是复位信号,低有效, 仿真q出现xxxx是因为你的仿真信号中的clear一直在翻转,所以一会复位,一会无效。 仿真程序中 begin clear=1'b1; forever #30 clear=~clear; end 把forever #30 clear=~clear;这句话去掉,然后clear赋初值为0,先复位在置1。 程序这段改为 begin clear=1'b0; #30 clear=1'b1; end 这样你在试试。 |
|
|
|
youzizhile 发表于 2014-4-16 17:31 谢谢,clear翻转确实太快了,但是我不太明白,虽然翻转快了,但是还是有时间间隔的吧,难道仿真器识别不了? |
|
|
|
因为你的时钟周期是20个单位时间,而clear周期是60个单位时间,也就是说,有效的工作时间只有30个单位时间,当clear=1时,程序还没有进行输出就被复位了 |
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
1533 浏览 1 评论
1313 浏览 0 评论
矩阵4x4个按键,如何把识别结果按编号01-16(十进制)显示在两个七段数码管上?
1523 浏览 0 评论
925 浏览 0 评论
2317 浏览 0 评论
1463 浏览 35 评论
5674 浏览 113 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-11-25 20:14 , Processed in 0.622407 second(s), Total 82, Slave 65 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号