欢迎来到天天文库
浏览记录
ID:20367091
大小:193.30 KB
页数:7页
时间:2018-10-12
《eda课程设计—秒表》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
1、EDA课程设计姓名:王亮学号:2012118064班级:1211自动化、课程设计0的1、熟练利用VerilogHDL语言进行数字系统设计。2、掌握数字系统的设汁方法一一自顶向下的设汁思想。3、掌握计数器的设计与使用。4、根据秒表的功能要求设计一个秒表。5、熟练掌握用QuartusII软件进行系统原理图设计、文本设计以及进行波形仿真。二、课程设计所需器材装有Quartusll软件的电脑一台、FPGA教学实验系统一台、下载电缆一根。三、课程设计要求1、有秒、分汁数,数码扫描显示输出。2、有清零端和暂停端。3、下载,检查结果是否正确
2、。U!1、功能描述秒表是一种计时的工具,有着很广泛的用途。本实验屮的秒表要求有两个功能按钮:一个是计数和停止计数按钮,当第一次按下此按钮时,秒表开始计数,再一次按下时,秒表停止计数,并显示所计的数字;另一个是清零按钮,当按下此按钮时,秒表清零。在数码管上釆用动态扫描显示输出。2、基本原理:本设计屮用到的主要元件有计数器、分频器、数据选择器、译码器、位选信号发生器等。秒、分都是60进制计数,所以必须采用两个60进制的计数器,而百分秒择采用的是100进制;分频器主要将1KHZ的时钟信号经过10分频后,产生100HZ的单位时钟周期;
3、数据选择器主要功能是将即将显示的数据送给译码器;译码器将BCD码转换为七段译码进行显示;位选信号发生器根据人眼暂留效应和显示的数码的个数,产生一段循环码。3、自顶向下的设计方法自顶向下的设计方法是数字系统设计中最常用的设计方法,也是基于芯片的系统设计的主要方法。自顶向下的设计方法利用功能分割手段将设计由上到I进行层次话和模块化,及分层次、分模块进行设计和仿真。功能分割时,将系统功能分解为功能块,功能块再分解为逻辑块,逻辑块再分解为更少的逻辑块和电路。如此分割,逐步的将系统细化,将功能逐步的具体化,模块化。高层次设计进行功能和接
4、U描述,说明模块的功能和接口,模块功能的更详细描述在下一设计层次说明,最底层的设计才涉及具体寄存器和逻辑门电路等实现方式的描述。五、课程设计步骤1、采用自顶向下的设计方法,首先将系统分块。2、设汁元件,及逻辑块。3、一级一级向上进行元件例化,设计顶层文件。4、把各模块连接起来,进行综合编译仿真。5、下载到实验箱,以验证程序。六、课程设计设计1、分频模块将输入1KHZ的系统时钟经过十分频分为100HZ的单位时钟。编程原理跟计数器原理相似。2、定时模块采用2个60进制、1个100进制的BCD码全加器作为定时器,分力分,秒,百分秒,
5、输入时钟信号为分频器输出信号100HZ时钟,外界两个拨码开关作为清零按钮和暂停按钮。3、位选发生器:根据显示的数据位和人眼暂留效应,设计显示分为分、秒、百分秒位,每位需要2个数码管进行显示,因此变化频率至少为300HZ,为了方便则采用1KHZ,循环码则从000循环到101。4、多路选择器根据位选信号,输出对应位显示的数据。5、译码器将多路选择器输出端的数据对应的转换为七段二进制数,送给显示器。各个分模块如下图所示:6、原理框阁如下阁t=>-^r-ekcfelO•JJ:j<••••••***«****•*•***•«•***•*
6、****•*>:c*IS-c*UUI20)boutJ2..01nst七、总结在课没制作开始时,自己就按照实验指导书挨着挨着的做实验,把前4个实验做完后,自己对Quaetusll软件及VerilogHDL语言语法掌握得也比较熟练了,在前儿个实验的铺垫下,秒表设计可以说是前儿个小实验的系统集成,专周感觉比较顺利。遇到的问题主要就是,在进行原理图设计时,定时器原件块和多路选择器原件块输出、输入接错了,导致波形仿真失败。通过多方面的学习了解,我学会了原理图设计法、文本输入没计法,同时也感受到了自顶而下和自下而上设计思路的优势。Veri
7、log源程序的编写很容易出现错误,这就需要耐心的调试。因为很多情况下,一长串的错误往往是由一个不经意的小错误引起的。当程序屡调屡错的吋候,最好和其他同学沟通交流一下,他们不经意的一句话,就可能给我启发,使问题迎刃而解。这次实习,给我感触最深的还是行为态度问题。人的能力有大有小,但只要端正态度,不抛弃,不放弃,任何人都能取得令自己满意的成绩。在此,我由衷的感谢在这次课程设计中给了我巨大帮助的老师和同学们!附:设计模块VerilogHDL源程序1、位选信兮发生器Functionname:bcFunction:locationoft
8、hedisplaymodulebc(clk'bout);inputelk;output[2:0]bout;reg[2:0]bout;always@(posedgeelk)beginjf(bout==3,bl01)bout=3'bOOO;elsebout=bout+l;ende
此文档下载收益归作者所有