




已阅读5页,还剩7页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
课程名称:VHDL数字系统设计与测试题 目 计数显示电路 学 院 电子工程学院 学 号 姓 名 马泽伟 一 设计功能和要求要求:设计一个输出为3位BCD码的计数显示电路。该计数显示电路由三个模块构成:1、十进制计数器(BCD_CNT)2、七段显示译码器电路(DEC_LED)3、分时总线切换电路(SCAN)。该电路功能为通过对外部一信号脉冲进行计数,并以十进制进行计数,计到百位。同时利用数码管动态扫描原理进行三位数码管进行显示出来。二 设计思路整个设计分十进制计数器模块(BCD_CNT)、分时总线切换电路模块(SCAN)和七段显示译码器电路模块(DEC_LED)构成。总的输入为十进制计数器时钟clk_1k,异步复位清零信号rst_n,分时总线切换电路时钟clk_1m。在rst信号为0期间,在每个clk的上升沿计数器将加1。在每个clk_1k的上升沿将会改变对三个数码管的扫描选通。总的输出为数码管选通信号sel(三位),输出到七段数码管的数据信号led(七位)。电路原理图如下:根据设计思路,设计详细的电路原理图如下:利用quartus进行综合生成RTL电路如下图:顶层模块逻辑结构图如下:顶层模块主要将十进制计数器、分时总线切换和七段显示译码模块进行连接搭建。其中从十进制模块中输出的data13:0、data23:0、data33:0分别为个、十、百位的BCD码。分时总线切换的输出data3:0为其中要显示的一个BCD码和位选信号一一对应。1.十进制计数模块十进制模块输入输出IO口有计数时钟输入sysclk、系统复位端rst_b、BCD输出端data和进位端co。当计数时钟端来一脉冲时,data将会计数,当来10个脉冲时,data端将会清零,并且产生一个进位脉冲信号。如此将三个十进制模块通过进位端co进行级联,则可成为百位BCD计数器。2.分时总线切换这个模块时本设计的重点和难点,分时总线切换经过系统时钟进行分频得到扫描时钟,每当扫描时钟上升沿时,进行切换,使得当data_sel2:0=”011”,data3:0=data13:0,依次类推。3.七段显示译码将data3:0的BCD码译码成为数码管显示码,采用共阴极.四:源代码设计1.顶层模块代码LIBRARY IEEE; USE IEEE.STD_LOGIC_1164.ALL; USE IEEE.STD_LOGIC_UNSIGNED.ALL; ENTITY declariation ENTITY display IS PORT ( Global system input sysclk : in STD_LOGIC; rst_b : in STD_LOGIC; tim_clk: in STD_LOGIC; Output ports data_sel : out STD_LOGIC_VECTOR(2 DOWNTO 0); data_ out : out STD_LOGIC_VECTOR(6 DOWNTO 0) ); END ENTITY; Architecture declaritionARCHITECTURE code of display isSignal declarationSIGNAL data1,data2,data3 : STD_LOGIC_VECTOR(3 DOWNTO 0);SIGNAL temp : STD_LOGIC_VECTOR(3 DOWNTO 0);SIGNAL co1,co2 : STD_LOGIC;COMPONENT BCD_CNTCOMPONENT BCD_CNT PORT ( Sysclk : IN STD_LOGIC; rst_b : IN STD_LOGIC; dataout: OUT STD_LOGIC_VECTOR (3 DOWNTO 0); co : OUT STD_LOGIC ); END COMPONENT;COMPONENT DEC_LEDCOMPONENT DEC_LED PORT ( data_in : IN STD_LOGIC_VECTOR(3 DOWNTO 0); data_out : OUT STD_LOGIC_VECTOR(6 DOWNTO 0) ); END COMPONENT;COMPONENT SCANCOMPONENT SCAN PORT ( sysclk : IN STD_LOGIC; rst_b : IN STD_LOGIC; data1 : IN STD_LOGIC_VECTOR(3 DOWNTO 0); data2 : IN STD_LOGIC_VECTOR(3 DOWNTO 0); data3 : IN STD_LOGIC_VECTOR(3 DOWNTO 0); data_out : OUT STD_LOGIC_VECTOR(3 DOWNTO 0); data_sel : OUT STD_LOGIC_VECTOR(2 DOWNTO 0) ); END COMPONENT; BEGIN U1: BCD_CNT PORT MAP (sysclk = tim_clk,rst_b = rst_b,dataout = data1,co = co1); U2: BCD_CNT PORT MAP (sysclk = co1 , rst_b = rst_b,dataout = data2,co = co2); U3: BCD_CNT PORT MAP (sysclk = co2 ,rst_b = rst_b,dataout = data3); U4: SCAN PORT MAP (sysclk = sysclk , rst_b = rst_b,data1 = data1, data2=data2, data3 = data3, data_out = temp, data_sel = data_sel); U5: DEC_LED PORT MAP (data_in = temp, data_out = data_out); END code;1. 十进制模块该模块完成bcd码的计数过程,每当系统时钟的上升沿到来,计数器的低位加1,满10进位,依次类推完成计数功能,复位信号使计数器清零。源程序如下:LIBRARY IEEE; USE IEEE.STD_LOGIC_1164.ALL; USE IEEE.STD_LOGIC_UNSIGNED.ALL;Entity declarationENTITY BCD_CNT IS PORT ( sysclk : IN STD_LOGIC; rst_b : IN STD_LOGIC; dataout: OUT STD_LOGIC_VECTOR (3 DOWNTO 0); co : OUT STD_LOGIC );END BCD_CNT;Architecture declarationARCHITECTURE cnt OF BCD_CNT ISSignal declartionSIGNAL temp : STD_LOGIC_VECTOR (3 DOWNTO 0); BEGIN PROCESS (sysclk,rst_b) BEGIN IF rst_b = 0 THEN temp = 0000; ELSIF sysclkevent AND sysclk = 1 THEN IF temp = 1001 THEN temp = 0000; ELSE temp = temp + 1; END IF; END IF; END PROCESS; PROCESS(temp) BEGIN IF temp = 0000 THEN co = 1; ELSE co = 0; END IF; END PROCESS; dataout = temp;END cnt;2.分时总线切换模块也即数码管刷新电路,其实质是一个在高频时钟控制下的多路数据选择器,在这里为三路数据选择器。源程序如下:LIBRARY IEEE; USE IEEE.STD_LOGIC_1164.ALL; USE IEEE.STD_LOGIC_UNSIGNED.ALL; Entity declarationENTITY SCAN IS PORT ( Global input ports sysclk : IN STD_LOGIC; rst_b : IN STD_LOGIC; data1 : IN STD_LOGIC_VECTOR(3 DOWNTO 0); data2 : IN STD_LOGIC_VECTOR(3 DOWNTO 0); data3 : IN STD_LOGIC_VECTOR(3 DOWNTO 0); Output ports data_out : OUT STD_LOGIC_VECTOR(3 DOWNTO 0); data_sel : OUT STD_LOGIC_VECTOR(2 DOWNTO 0) ); END ENTITY; Architecture declarationARCHITECTURE code OF SCAN ISSignal declarationSIGNAL count : STD_LOGIC_VECTOR (3 DOWNTO 0);SIGNAL SEL_NUM : STD_LOGIC_VECTOR (1 DOWNTO 0);BEGIN PROCESS(sysclk,rst_b) BEGIN IF rst_b = 0 THEN count = 0000 ; ELSIF sysclkevent AND sysclk = 1 THEN count = count + 1; END IF; END PROCESS; PROCESS (count,sysclk,rst_b) BEGIN IF rst_b = 0 OR SEL_NUM = 11 THEN SEL_NUM = 00; ELSIF sysclkevent AND sysclk = 1 THEN IF count = 0000 THEN SEL_NUM data_sel data_sel data_sel data_sel data_out data_out data_out data_out data_out data_out data_out data_out data_out data_out data_out data_out data_out data_out data_out = ; END CASE; END PROCESS;END code;六功能仿真顶层模块,即系统设计模块波形图如下:结果分析:输入系统时钟为25MHZ,而计数时钟为250KHZ,从图中可以看到输入时钟波形。而输出数据则经过一定的时钟,位选数据交替变换,而7段译码数据随之更新。从这里可以得知功能正确,但不能看到数据是否符合要求。因此需要看各个模块的波形。十进制模块波形仿真如下:结果分析:从上图可以看出当输入时钟上升沿时,则data将BCD计数,当第十个脉冲来时,data清零并且输出一个进位脉冲,功能和数据均符合设计要求。分时总线切换模块仿真波形如下:结果分析:分时总线切换模块主要功能就是将三位BCD码,经一扫描时钟进行依次切换输出,当位选数据data_sel=011时,数据输出data_out=data1;当data_sel=101时,数据输出data_out=data2;当data_sel=110时,数据输出data_out=data3。从上图波
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 一千根弦续写350字10篇范文
- 我的语文老师350字(12篇)
- 时尚的鸭子课件
- 小学生元宵节作文202514篇
- 纪检业务知识培训课件讲稿
- 早期报警实操培训知识课件
- 《新编商务应用文写作》第二章 习题参考答案
- 商业场地租赁合同解除协议
- 2025年无损检测资格证考试超声波无损检测工程师试卷
- 纪律处分条例课件教学
- 2025个人政治素质自查自评报告
- 摄影课件拍摄角度
- 技术经纪人基本知识培训课件
- 研发项目管理流程及质量控制措施
- 2025年北交所开通测试题及答案
- 2025年国家安全知识竞赛题库试题(附答案)
- 2025年法人试题及答案
- 水稻全程机械化栽培技术
- 2025年患者转运与护理知识试题附答案
- 浙江省2025年中考语文真题试卷及答案
- 物流跟踪管理办法
评论
0/150
提交评论