- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
简易数字跑表设计
西安郵電 学生姓名 : 专业名称 : 自动化 班 级 : 自动1103 时间 : 2014年9月1日 至2014年9月12日
简易数字跑表的设计
设计要求:
计时精度10ms,计时范围59.99秒。
对单人计时,能实现暂停、显示及清零功能,在数码管上实时显示,设置启动/暂停、清零按键;
对多个人同时计时,在数码管上实时显示,并能回显出六个时间。可控制显示,设置清零、取时按键;
采用状态机设计;
百分秒在数码管上实时显示,秒利用多个数码管显示BCD值。
二、设计过程:
1.查找资料:数字系统设计与Verilog HDL(第4版)
2.方案设计:
(1)画状态图:
按键 状态 输出
复位:00 开始:S0 清 零:z=0;
启/停:01 计数:S1 不清零:z=1;
存/回显:10 暂停:S2
存/回显:S3
图1.程序状态图
(2)写程序:
·在一个module模块里,有多个always块;
·有分频、计数、存储、输出等模块;
·测试模块的输入输出与源程序的输入输出相反;
3.系统仿真:
Verilog仿真所需仿真环境:modelsim
4.硬件调试
三、软件设计:
1.源程序:
module paobiao(clk,rst,pause,save,mg,md,bg,bd);//秒高,秒低,百分 秒高,百分秒低
input clk,rst,pause,save;
output reg [3:0] mg,md,bg,bd;
reg [15:0] zd,zz,zg;//中间变量
reg [17:0] count1;
reg clk1;//100ms
reg pause_temp,save_temp;//取上升沿
reg [13:0] count2,reg0,reg1,reg2,reg3,reg4,reg5;
reg [2:0] count3;//
reg [1:0] state,next_state;
reg cn1;
parameter S0=2b00,S1=2b01,S2=2b11;
//分频
always @(posedge clk or negedge rst)
begin if(!rst) count1=0;
else if(count1==200000) count1=0;//200000
else count1=count1+1;
end
always @(posedge clk )
begin if(!rst) clk1=0;
else if(count1==99999) clk1=~clk1;//99999
else clk1=clk1;
end
//总计时
always @(negedge clk1 or negedge rst)//clk1
begin if(!rst) count2=0;
else if(state==S1) count2=count2+1;
// else if(state==S2) count2=count2;
else count2=count2;
end
//存储个数计数
always @(negedge rst or negedge save)
begin if(!rst) count3=0;
else if (next_state==S1) count3=count3+1;
else if (next_state==S2) count3=count3-1;
else count3=count3;
end
//毫秒低位显示结果
always @(negedge rst or posedge clk)
begin if(!rst) bd=0;
else if(state==S1) bd=count2%10;
else if(state==S2) begin case (count3)
3b000: bd=reg0%10;
3b001: bd=reg1%10;
您可能关注的文档
最近下载
- 统编版必修中外历史纲要上《第3课 秦统一多民族封建国家的建立》公开课一等奖创新教学设计.docx VIP
- 2025年北京市东城区九年级初三一模数学试卷(含答案).pdf VIP
- 睾丸扭转--精品课件.ppt VIP
- 科技三项费用管理办法.doc VIP
- CB-T 4537-2023船舶行业企业隐患治理管理规定.pdf VIP
- YY_T 1453-2016组织工程医疗器械产品 I型胶原蛋白表征方法.pdf
- 大学生毕业论文写作教程PPT全套教学课件.pptx
- 拱形屋面板高支模专项方案1.doc VIP
- 2025年辅警招聘考试题题库(含参考答案).docx VIP
- 船舶行业企业隐患治理管理规定.pdf VIP
文档评论(0)