简易数字跑表设计.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 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;

文档评论(0)

gk892289 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档