《电子综合实验报告——数字钟.docVIP

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

电子综合实验报告——数字钟 实验题目:数字钟 实验内容: 设计一个带闹钟功能的24小时计时器。它包括以下几个组成部分:①?显示屏,由8个七段数码管组成,用于显示当前时间(时:分:秒)或正在设置的当前时间;②?Time键、HSet键、MSet键分别用来启动设置时钟的时、分;③?复位键,用来还原时钟到初始默认值;④?Alarm键,用于启动设置闹钟时间;⑤?A键组,用于输入2进制闹钟时间;⑥扬声器(这里用一个发光二极管代替),在当前时钟时间与闹钟时间相同时,发出蜂鸣声(二极管亮)。? 主要功能:? (1)?计时功能:这是本数字闹钟设计的基本功能,每隔一分钟计时一次,并在显示屏上显示当前时间。? (2)?闹钟功能:如果当前时间与设置的闹钟时间相同,则“扬声器”发出“蜂鸣声”(二极管亮)。? (3)?设置新的数字钟时间:用户用Time键、HSet键、MSet键对当前时间进行修改。? (4)?设置新的闹钟时间:用户用Alarm键及A键组对闹钟时间进行修改。? (5)?显示所设置的闹钟时间:A键组直接展示输入的闹钟时间。 设计方案 根据系统的设计要求,整个系统分为4个模块:时间计数器、闹钟寄存器、分频器、数码管显示模块。?功能介绍:? ?(1)?时间计数器:实际上是一个异步复位、异步置数的累加器,通常情况下进行时钟累加计数,必要时可置入新的时钟值,然后从该值开始新的计数。? (2)?闹钟寄存器:用于保存用户设置的闹钟时间,并可设置新的闹钟时钟时间并判断当前时间是否等于闹钟时间。 (3)分频器:把板上输入的6MHz的频率分为1Hz和1kHz,1Hz用于数码管显示,1kHz用于时钟计时。 (4)数码管显示模块:用来显示闹钟时间或当前时间。 设计思路:? 顶层RTL图: (一)时间计数器:? ??????在正常计时,前面计数器的cout(进位端)作为下一个计数器的信号。当修改当前时间时,选用频率更快的信号,使所显示的时间的值较快的达到要设定的值。此处用一个2选1的选择器来选择适当的信号。此处分和时的修改是分开进行的,分别用Mkey和Hkey进行控制(即:他们作为多路选择器的sel信号)。 VHDL语言: library ieee; use ieee.std_logic_1164.all; use ieee.std_logic_unsigned.all; entity times is port(clk_1Hz:in std_logic; set:in std_logic; rst:in std_logic; s1:in std_logic; s2:in std_logic; z:out std_logic; sec_l,sec_h:out std_logic_vector(3 downto 0); min_l,min_h:out std_logic_vector(3 downto 0); hour_l,hour_h:out std_logic_vector(3 downto 0)); end times; architecture behave of times is signal zd:std_logic; begin process(clk_1Hz,set,rst,s1,s2,zd) variable msecond1:std_logic_vector(3 downto 0):=1000; variable msecond2:std_logic_vector(3 downto 0):=0101; variable mminute1:std_logic_vector(3 downto 0):=0100; variable mminute2:std_logic_vector(3 downto 0):=0011; variable mhour11:std_logic_vector(3 downto 0):=1000; variable mhour22:std_logic_vector(3 downto 0):=0000; begin if clk_1Hzevent and clk_1Hz=1then if mminute1=0000 and mminute2=0000 then zd=1; else zd=0;

文档评论(0)

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

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

1亿VIP精品文档

相关文档