- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
(电子行业企业管理)基
于的电子闹钟设计
基于 VHDL 的数字闹钟设计
摘要:随着 EDA 技术的发展和应用领域的扩大与深入,EDA 技术在电子信息、通
信、自动控制及计算机应用领域的重要性日益突出。EDA 技术就是依赖功能强大
的计算机,在EDA 工具软件平台上,对以硬件描述语言 VHDL 为系统逻辑描述手
段完成的设计文件,自动地完成逻辑优化和仿真测试,直至实现既定的电子线路
系统功能。本文介绍了基于VHDL 硬件描述语言设计的多功能数字闹钟的思路和
技巧。在 Quartus11 开发环境中编译和仿真了所设计的程序,并逐一调试验证程
序的运行状况。仿真和验证的结果表明,该设计方法切实可行,该数字闹钟可以
实现调时定时闹钟播放音乐功能具有一定的实际应用性。
关键字:闹钟FPGAVHDLQuartusII
一、电子钟相关功能描述如下:
(1)计时功能:这是本计时器设计的基本功能,可进行时、分、秒计时,并
显示。
(2)闹钟功能:如果当前时间与设置的闹钟时间相同,则扬声器发出一段音
乐,并维持一分钟。
(3)调时调分调闹钟功能:当需要校时或者要重新设置闹钟的时间时,可通
过实验箱上的按键控制。
二、设计原理:
数字闹钟电路的基本结构由两个 60 进制计数器和一个 24 进制计数器组成,
分别对秒、分、小时进行计时,当计时到 23 时 59 分 59 秒时,再来一个计数脉
冲,则计数器清零,重新开始计时。秒计数器的计数时钟 CLK 为 1Hz 的标准信号。
当数字闹钟处于计时状态时,秒计数器的进位输出信号作为分钟计数器的计数信
号,分钟计数器的进位输出信号又作为小时计数器的计数信号时、分、秒的计时
结果通过 6 个数码管来动态显示。数字闹钟除了能够正常计时外,还应能够对时
间进行调整。因此,通过模式选择信号KEY1 、KEY2 控制数字钟的工作状态,即
控制数字钟,使其分别工作于正常计时,调整分、时和设定闹钟分、时 5 个状态。
当数字闹钟处于计时状态时,3 个计数器允许计数,且秒、分、时计数器的计数
时钟信号分别为CLK,秒的进位,分的进位;当数字闹钟处于调整时间状态时,被调
的分或时会一秒一秒地增加;当数字钟处于闹钟定时状态时,可以设定小时和分;
当计时到所设定的时刻时,speak 将会被赋予梁祝音乐信号用于驱动扬声器,持
续 1 分钟。
三、实验代码:
1)顶层文件:
LIBRARYIEEE;
USE_LOGIC_1164.ALL;
ENTITYclockIS
PORT(CLK12MHZ:INSTD_LOGIC;
CLK8HZ:INSTD_LOGIC;
SPKOUT:OUTSTD_LOGIC;
CLK:INSTD_LOGIC;
KEY1:INSTD_LOGIC;
KEY2:INSTD_LOGIC_VECTOR(1DOWNTO0);
H1,H2,M1,M2,S1,S2:OUTSTD_LOGIC_VECTOR(3DOWNTO0));
END;
ARCHITECTUREoneOFclockIS
COMPONENTshizhong
PORT(clk:instd_logic;
md1:instd_logic;
md2:instd_logic_vector(1downto0);
clken:outstd_logic;
h1,h2,m1,m2,s1,s2:outstd_logic_vector(3downto0));
ENDCOMPONENT;
COMPONENTNoteTabs
PORT(clk:INSTD_LOGIC;
ToneIndex:OUTSTD_LOGIC_VECTOR(3DOWNTO0));
ENDCOMPONENT;
COMPONENTToneTaba
PORT(Index:INSTD_LOGIC_VECTOR(3DOWNTO0);
Tone:OUTSTD_LOGIC_VECTOR(10DOWNTO0);
en:instd_logic);
ENDCOMPONENT;
COMPONENTSpeakera
PORT(clk:INSTD_LOGIC;
Tone:INSTD_LOGIC_VECTOR(10DOWNTO0);
SpkS:OUTSTD_LOGIC);
ENDCOMPONENT;
SIGNALTone:STD_LOGIC_VECTOR(10DOWNTO0);
SIGNALTon
文档评论(0)