EDA原理第11章数字时钟设计.ppt_第1页
EDA原理第11章数字时钟设计.ppt_第2页
EDA原理第11章数字时钟设计.ppt_第3页
EDA原理第11章数字时钟设计.ppt_第4页
EDA原理第11章数字时钟设计.ppt_第5页
已阅读5页,还剩31页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

该电子教案为一书的配套教学资源 版权所有,不得用于其它商业用途 数字时钟设计及实现 何宾 2011.09 数字时钟设计-本章概要 本章给出了PLD器件在复杂数字系统的典型应用实例- 数字时钟的设计。数字时钟的设计也是PLD在复杂数字 系 统的经典应用。 该章首先介绍了数字时钟的功能要求和整体结构;随 后 具体介绍了数字时钟的模块设计,其中包括数字时钟控 制 信号和控制模块的具体结构。本章最后详细描述了设计 的 具体实现过程,具体包括数字时钟的计数模块设计、计 数 时钟及扫描时钟设计和显示控制模块设计。 数字时钟设计-数字时钟的功能要求 数字钟时常见的一种计数装置,数字钟以1Hz的频率 工 作。该设计完成数字钟的运行和显示。其主要功能有: 1、数字钟以1Hz的频率工作,其输入频率为1MHz。 2、数字钟显示时、分、秒信息。这些显示信息在6个7 段数码管上完成。 3、通过按键设置时、分信息。并且具有对数字钟的复 位功能。 4、复位键将时、分、秒清零,并做好重新计数的准备 。 5、按键具有预置时、分的功能。分别对当前的时和分 信息做递增设置和递减设置。 数字时钟设计-数字时钟的结构 数字时钟设计-数字时钟的结构 该数字钟的控制部分由PLD芯片完成。该芯片的输入 和输出接口由下面信号组成: 输入信号: l复位信号(reset) l时钟输入信号(clk) l小时递增信号(inc_hour) l小时递减信号(sub_hour) l分钟递增信号(inc_min) l分钟递减信号(sub_min) 输出信号: l7段数码管选信号(sel) l7段数码管段选信号(q) 数字时钟设计-控制模块结构 该设计分成下面四个模块:定时时钟模块、扫描时钟 模 块、按键处理模块、定时计数模块和显示控制模块。图 11.2给出了这几个模块之间的信号连接关系。 数字时钟设计-控制模块结构 1、按键处理模块 由于VHDL语言的规则,将按键的处理和定时模块设 计 在一起。为了描述清楚,将对按键的处理进行说明。在 该 设计中,采用异步复位电路方式。当复位信号低有效时 , 计数器停止计数,时、分、秒清零。 对于小时的递增、递减按键操作,通过一个1Hz的计 数 时钟采样。图11.3给出了递增、递减的操作时序。 数字时钟设计-控制模块结构 数字时钟设计-控制模块结构 当1Hz的div_clk信号的上升沿到来时,检测 hour_inc 和hour_dec按键,图中的虚线表示在时钟的上升沿 对 按键信号进行采样。当hour_inc或hour_dec按键低有 效 时,对小时进行递加或递减操作。 对于分钟的递加、递减按键操作,也是通过一个 1Hz的计数时钟采样。原理同图11.4。 数字时钟设计-控制模块结构 2、定时时钟模块 定时时钟模块其作用就是将外部提供的1MHz的时钟, 通过分频器后向模块内的定时计数模块提供1Hz的定时 计 数时钟。在设计定时时钟模块时,采用同步计数电路。 数字时钟设计-控制模块结构 3、扫描时钟模块 扫描时钟模块的作用就是通过对1MHz的分频处理后 , 向显示控制模块提供合适的显示扫描时钟,该时钟必须 经 过合理的设计,才能保证7段数码显示的稳定。在设计 扫 描时钟模块时,采用同步计数电路。 数字时钟设计-控制模块结构 4、定时计数模块 定时计数模块是该设计中最重要的一部分,在设计该 模 块时,为了便于后续显示控制模块的设计,将时、分、 秒 进行分离,即小时分成了小时的十位和个位分别处理, 分 钟分成了分钟的十位和个位分别处理。秒分成了秒的十 位 和个位分别处理。在该设计中,采用24小时计数模式。 例如:13:28:57。13为小时的表示,1为小时的十 位,3为小时的个位;28为分钟的表示,2为分钟的十位 , 8为分钟的个位;57为秒的表示,5为秒的十位,7为秒 的 个位。 数字时钟设计-控制模块结构 秒的个位计数从0-9,即十进制计数。当秒的个位计 数到9后,准备向秒的十位进位。秒的十位计数从0-5, 即 六进制计数。当秒的十位计数到5后,准备向分的个位 进 位。 分钟的个位计数从0-9,即十进制计数。当分钟的个 位 计数到9后,准备向分钟的十位进位。分钟的十位计数 从 0-5,即六进制计数。当分钟的十位计数到5后,准备向 小 时的个位进位。 数字时钟设计-控制模块结构 对于小时的处理比较复杂,小时的十位和个位之 间存在下面的关系: 当小时的十位为0或1时,小时的个位可以计数范 围为0-9,即十进制计数; 当小时的十位为2时,小时的各位可以计数的范 围 为0-3,即四进制计数; 数字时钟设计-控制模块结构 数字时钟设计-控制模块结构 5、显示控制模块 显示控制模块主要作用是在7段数码管上正确的显示 0- 9的数字。sel三位选择线和3-8译码器相连 数字时钟设计-主程序 library IEEE; use IEEE.STD_LOGIC_1164.ALL; use IEEE.STD_LOGIC_ARITH.ALL; use IEEE.STD_LOGIC_UNSIGNED.ALL; -实体定义部分 entity clock is port( clk : in std_logic; rst : in std_logic; inc_min : in std_logic; sub_min : in std_logic; inc_hour : in std_logic; sub_hour : in std_logic; sel : out std_logic_vector(2 downto 0); q : out std_logic_vector(7 downto 0); end clock; -信号定义: architecture Behavioral of clock is signal sec_counter1:std_logic_vector(3 downto 0); signal sec_counter2:std_logic_vector(3 downto 0); signal min_counter1:std_logic_vector(3 downto 0); signal min_counter2:std_logic_vector(3 downto 0); signal hour_counter1:std_logic_vector(3 downto 0); signal hour_counter2:std_logic_vector(3 downto 0); signal divcounter : std_logic_vector(3 downto 0); signal div_clk : std_logic; signal scancounter : std_logic_vector(1 downto 0); signal scan_clk : std_logic; signal scan_out : std_logic_vector(2 downto 0); signal secseg1,secseg2,minseg1,minseg2,hourseg1,hourseg2:std_logic_vector( 7 downto 0); begin 数字时钟设计数字时钟设计- -主程序主程序 -计数时钟,对外部输入时钟分频,此处只适用于仿真, 实际进行时间计数时,分频后时钟应该满足1HZ。 process(rst,clk) begin if(rst=0)then divcounter=X“5“) then min_counter2=X“9“) then sec_counter1=X“5“) then sec_counter2=X“9“) then min_counter1=X“5“) then min_counter2 q q q q q q q secseg1 secseg1 secseg1 secseg1 secseg1 secseg1 secseg1 secseg1 secseg1 secseg1 secseg1 secseg2 secseg2 secseg2 secseg2 secseg2 secseg2 secseg2 minseg1 minseg1 minseg1 minseg1 minseg1 minseg1 minseg1 minseg1 minseg1 minseg1 minseg1 minseg2 minseg2 minseg2 minseg2 minseg2 minseg2 minseg2 hourseg1 hourseg1 h

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论