网站大量收购闲置独家精品文档,联系QQ:2885784924

电子科技大学ASIC秒表计时电路实验分解.doc

  1. 1、本文档共14页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
电子科技大学通信学院 秒表计时电路实验报告 班 级 学 生 学 号 实验时间 2015年11月27日 一、设计思路概述 设计要求:秒表计时功能,显示分、秒、0.01秒;;;; .设计分析:本设计要求秒表计时功能,显示分、秒、0.01秒,而这可以由分频电路实现,将电路的输入时钟进行分频,得到1/60Hz,1Hz,和100Hz信号,就可以达到本设计要求的显示要求了;本设计要求具有启动、暂停、停止和清空功能,而这个可以由状态机实现,通过合理的配置状态转换,就可以达到要求。 流水灯的实现:单个灯从左到右逐步发光。相当于是一个移位寄存器,我们可通过不同的时钟来驱动它,实现不同的流水速度。这里,我们实现了一个1Hz,和一个10Hz的流水灯电路。 二、总体设计框图及详细说明 状态机实现清零、暂停、停止等状态的切换由2比特的key信号控制,计数器500000进制由输入时钟产生周期0.01s的时钟,这是显示时钟信号的最小单位。计数器10进制可实现10分频,由他产生的输出时钟为输入时钟周期的10倍,并根据他的状态即计数量作为输出显示对应位的时间信号,6进制实现6分频,实现功能类似于计数器10进制,通过如框图中的组合可产生时钟信号的不同位。显示译码电路显示时钟,输出56位,因为时钟信号具有8位,输出信号连到相应的数码管即可。 三、模块设计框图、相关时序 1.6进制计数器(分频器)设计 //计数器实现6分频,计数到达2和5,输出始终翻转一次,且计数达到5时计数清零 module count6(rst, clk, clkout, counter); input rst; input clk; output reg clkout; output reg [3:0]counter; always @(negedge clk or negedge rst) begin if (~rst) begin clkout = 0; counter = 0; end else if (counter == 2 )begin clkout = ~clkout; counter = counter + 4b1; end else if (counter == 5) begin clkout = ~clkout; counter = 0; end else begin counter = counter + 4b1; end end endmodule 仿真结果为: 由图可知实现了6分频。 2、10进制计数器(分频器)设计 //计数器实现10分频,计数到达4和9,输出始终翻转一次,且计数达到9时计数清零 module count10(rst, clk, clkout, counter); input rst; input clk; output reg clkout; output reg [3:0]counter; always @(negedge clk or negedge rst) begin if (~rst) begin clkout = 0; counter = 0; end else if (counter ==4) begin clkout = ~clkout; counter = counter + 4b1; end else if (counter == 9) begin clkout = ~clkout; counter = 0; end else begin counter = counter + 4b1; end end endmodule 仿真结果为: 由图可知实现了10分频。 3、500000进制计数器(分频器)设计: //实现500000分频,目的是把50Mhz的系统时钟分频成为100Hz的 always @(negedge clk or negedge rst10ms) begin if (~rst10ms) begin clk10ms=0; clk10msreg=0; end else if (clk10msreg == 249999) begin clk10ms=~clk10ms ; clk10msreg=clk10

文档评论(0)

希望之星 + 关注
实名认证
内容提供者

我是一名原创力文库的爱好者!从事自由职业!

1亿VIP精品文档

相关文档