基于fpga的数字跑表设计大学本科毕业论文.doc

上传人:教**** 文档编号:88288245 上传时间:2023-04-24 格式:DOC 页数:44 大小:396KB
返回 下载 相关 举报
基于fpga的数字跑表设计大学本科毕业论文.doc_第1页
第1页 / 共44页
基于fpga的数字跑表设计大学本科毕业论文.doc_第2页
第2页 / 共44页
点击查看更多>>
资源描述

《基于fpga的数字跑表设计大学本科毕业论文.doc》由会员分享,可在线阅读,更多相关《基于fpga的数字跑表设计大学本科毕业论文.doc(44页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、本 科 毕 业 论 文基于FPGA的数字跑表设计Digital stopwatch design based on FPGA 学院名称: 电子信息与电气工程学院 专业班级: 电子信息工程(专升本)2013级 毕业设计(论文)原创性声明和使用授权说明原创性声明 本人郑重承诺:所呈交的毕业设计(论文),是我个人在指导教师的指导下进行的研究工作及取得的成果。尽我所知,除文中特别加以标注和致谢的地方外,不包含其他人或组织已经发表或公布过的研究成果,也不包含我为获得安阳工学院及其它教育机构的学位或学历而使用过的材料。对本研究提供过帮助和做出过贡献的个人或集体,均已在文中作了明确的说明并表示了谢意。作 者

2、 签 名: 日 期: 指导教师签名: 日期: 使用授权说明本人完全了解安阳工学院关于收集、保存、使用毕业设计(论文)的规定,即:按照学校要求提交毕业设计(论文)的印刷本和电子版本;学校有权保存毕业设计(论文)的印刷本和电子版,并提供目录检索与阅览服务;学校可以采用影印、缩印、数字化或其它复制手段保存论文;在不以赢利为目的前提下,学校可以公布论文的部分或全部内容。作者签名: 日 期: 目 录摘 要IAbstractII引 言1第一章 绪 论11.1 设计背景与意义11.2 跑表的发展趋势2第二章 实验的软件环境22.1 MAX+plus软件22.2 VHDL语言3第三章 跑表的设计53.1跑表的

3、方案选择53.2跑表的程序流程图63.3顶层设计与VHDL源代码73.3.1顶层实体设计及VHDL源代码73.3.2顶层结构体的设计83.4跑表的各个模块分析93.4.1键输入模块93.4.2时钟分频模块113.4.3控制模块133.4.4跑表计时模块143.4.5跑表显示模块173.5仿真结果20结 语22致 谢23参考文献24附录A 管脚引用表25附录B 跑表的程序代码26基于FPGA的数字跑表设计摘要:本数字跑表用于检测需要准确计时或计时场合较为精确且比较精密的环境中。在现在的竞赛、科研、测验的环境中,跑表依然扮演着十分重要的角色。随着电子技术的发展,它有着更加广阔的发展空间、也有着更加

4、广泛的应用。本论文对数字跑表进行了电路设计与程序设计,并划分为五个模块:键输入模块、分频模块、控制模块、计时模块和显示模块。各个模块通过合理的配合来实现跑表的功能,所有功能语言都用VHDL来完成描述。本实验主要借助Altera公司开发的EDA工具MAX+plus 软件作为编译和仿真的实验环境,主要利用EPF10K10LC84-4器件在FPGA的实验箱上来完成数字跑表的设计。关键词:跑表;VHDL语言;MAX+plus ;FPGADigital stopwatch design based on FPGAABSTRACT:The digital stopwatch for detection r

5、equires accurate timing or timing occasions more accurate and more sophisticated environment. In the current competition, scientific research, test environment, stopwatch still plays a very important role. With the development of electronic technology, it has a more broad development space, also has

6、 a more extensive application. In this paper, the digital stopwatch were hardware circuit design and software design, and is divided into five modules: key input module, frequency module, control module, timing module and display module. Each module is realized by the stopwatch with reasonable, all

7、functions are accomplished with VHDL description language. This experiment mainly by Altera corporation development of EDA tools MAX + PLUS II software as compilation and simulation experiment environment, the main use of epf10k10lc84-4 device in FPGA experimental box completed the design of digital

8、 stopwatch.Keywords: Stopwatch; VHDL language; MAX + plus ; FPGAII引 言本跑表无机械装置,是用电子设备来完成数字跑表的设计,它具有更长的使用寿命和更加精确的计时装置,因此才得到了广泛的应用。通过跑表的制作使我进一步的了解了各种中小规模集成电路的作用及特点,使我进一步的学习与掌握了各种组合逻辑电路与时序电路的原理和使用方法。 人生苦短,日月如梭。时间是人生中最珍贵的东西,但当事情不怎么重要的时候,这种遗忘倒不会出什么事。但一旦遇到了重要事情,一时的遗忘就会酿成大祸。例如:在医院中,病体发作时间频率值、手术的时间间隔、麻药的药效长短

9、等高危手术中,计时就显得尤为重要;在科研中,火箭的发射、飞机的起飞、导弹的攻击、航母的运行、空间站的对接等高科技产品中,一秒钟的误差就会产生极其严重的后果;在竞赛中,即使是相差0.01s那也会有一个先后,分秒必争的理念就变得尤为的突出;在工程的测试中;在万物生长中等等观测结果的情况下,这种对时间的精确度要求就变的非常高了,这时对于数字跑表的研究就变得尤为突出的重要。所以,制作一个精确计时的跑表系统是多么明智的选择。第一章 绪 论1.1设计背景与意义现在电子产品已经融入了我们身边的每个角落,它使我们的生活变的更加的美满和和谐,同时也使电子产品的性能进一步提高、功能进一步强大,其中带给我们最大的红

10、利就是便捷。现在的电子时钟也已经布满我们的生活里,如手机、电脑、手表、钟表以及各大中小地点的公共场所里都有时钟的出现。然而数字跑表的功能和用途有许多是电子钟无法用精确性和准确性来取代的,跑表有着这些独特的特点,也有着不可被取代的趋势。电子产品朝着高精度高准确度的方向发展,跑表依然如此。因此本设计不采用单片机、不采用机械设备、而采用基于FPGA来完成数字跑表的设计。随着现场可编程门阵列的发展,电子系统向着集成化、大规模和高速度等方向升级的趋势也愈加明显,所以设计本跑表为打开FPGA领域而研究FPGA数字跑表具有里程碑式的意义。1.2跑表的发展趋势数字跑表已经成为了人类在科技、竞赛和检测中的一种十

11、分必要的计时装置,给人们的生活、学习、工作、娱乐带来极大的方便。数字跑表的发展方向将会为以后的航空航天、航空母舰、高铁磁悬浮列车等科技方面做出更加可靠的计时参考和更加精确的依据,也会为竞技竞赛、公平竞争等项目比赛提供更加公平公正的参考。第二章 实验的软件环境2.1 MAX+plus软件本软件主要由层次显示器、信息处理器、输入编辑器、设计编译器、设计校验器和器件编程器一起构成了一个完整独立的EDA设计平台。 当程序编译完毕并能产生MAX+plus或第3方EDA工具的一系列文件和报告,如图2.1所示。MAX+plus编译器第三方EDA设计文件(.edf,.sch,.xnf)映射文件(.imf)MA

12、X+plus设计文件(.gdf,.tdf,).vhd)指定和配置信息 (.acf)第三方EDA仿真和定时文件(.edo,vo,vho,sdo)功能仿真(.snf)定时仿真(.snf)编程文件(.pof.sof.jed)图2.1 MAX+plus编译器定时分析器,有这样的分析模式:时序逻辑电路性能分析模式。分析时序电路的性能,包括限制性能上有限制的延迟,还有最小的时钟周期和最高的电路工作频率。MAX+plus的设计流程主要由设计输入、设计编译、功能仿真、时序仿真、器件编程等步骤来完成。2.2 VHDL语言经过多年的检测与使用,最终工程师们吧定为标准硬件描述语言。VHDL语言的主要优点是:(1)有

13、良好的可读性,容易被读者理解。(2) VHDL是通用硬件描述语言。(3)用它从事设计工作,不用考虑线路布局问题,降低了设计的复杂度。(4)接近于算法的推演,不必关心如何用逻辑电路实现这种算法的过程。VHDL语言结构体的完整格式如下:ARCHITECTURE 结构体OF实体名IS定义语句BEGIN并行语句1;并行语句2;END ARCHITECTURE 结构体名 ;VHDL中实体的完整格式如下:ENTITY 实体名 IS GENERIC (类属表); PORT (端口表); BEGIN 实体语句部分;END ENTITY 实体名; 它描述了一个系统或者电路的外观图。实体中的类属和端口用来说明所设

14、计的系统或者电路与其它模块通信的对象。实体语句部分定义实体接口中的公共信息。第三章 跑表的设计3.1跑表的方案选择 方案一:设计一款基于单片机的数字跑表。1. 核心用一块AT89C51和555定时器结合来完成;2. 硬件准备好后,编辑程序下载、调试、试运行;3. 试验成功后将其包装。 方案二:设计一款基于FPGA的数字跑表。 1.核心用FPGA开发平台和Max+plusII操作平台来完成; 2.程序编辑好后,用软件仿真运行;3.实验成功后将其展示。 方案比较: 相同点:这两种方案的原理相似都分别由计数部分、显示部分组成。都能按照设计要求完成有百分秒计时功能的数字跑表。不同点:方案一主要是单片机

15、来完成跑表,应用范围略广,但考虑到单片机本身的特点,不适合结合比较高端的设备。方案二应用领域比较广泛,能结合许多设备,能够更好、更精确的实现计时功能。 方案采用:根据以上方案分析和研究的可行性、价值性和意义性分析,数字跑表的设计采用方案二。方案二设计主要由五个主要模块组成:键输入模块(主要是消除抖动之类的);时钟分频模块(输出为100Hz用于计时、1kHz用于数码管动态扫描);使能控制模块(实现开始及暂停功能);计数器模块(由模十计数器和模六计数器级联);显示控制模块(包括数据选择和显示译码)。它是采用VHDL语言来设计的跑表系统,能通过计算机来完成,从而缩短了系统的开发时间,提高了系统的工作

16、效率。其主要特点描述如下:(1)启/停功能。在任何情况下只要按复位开关,跑表都会无条件地执行复位操作。(2)计时精度高于0.01秒,内部定时时钟信号频率采用1000Hz的时钟输入信号,以24h为最长计时周期。(3)对跑表进行更换电源操作是由系统电源复位电路提供给跑表的电源复位信号来控制跑表的复位操作。图3.1 跑表系统的结构框图3.2 开始跑表的程序流程图清零显示CLR=1Y NY SL=9 NSL=0 NYSH=5? SH=SH+1MH=0,CN2=1 结束图3.2 秒计数进程程序流程图 开始YCLR=1?清零显示 NYSL=9? NML=0 YSH=5? NMH=MH+1MH=0 结束图3

17、.3 分计数进程程序流程图3.3顶层设计与VHDL源代码3.3.1顶层实体设计及VHDL源代码在自顶向下的VHDL语言设计描述中,第一个应该考虑的是描述顶层信号接口,如图3.4所示。图3.4 跑表各个模块的连接关系VHDL的系统接口是由实体说明来描述的。下面是跑表顶层实体说明的VHDL源代码。源代码1library ieee;use ieee.std_logic_1164.all;use ieee.std_logic_arith.all;use ieee.std_logic_unsigned.all;entity stopwatch isport ( reset1 : in std_logic

18、; on_off : in std_logic; sysreset : in std_logic; clk : in std_logic; choose : out std_logic_vector(7 downto 0); segment : out std_logic_vector(6 downto 0);end stopwatch;3.3.2顶层结构体的设计因我们通常用的跑表大部分都由按键产生的,但这种操作会产生一定的误差,因为当需要计时的时候你的手按下的速度,和按键接触的速度以及弹簧反应的速度都直接影响计时的精度,因此设计一款消抖同步电路就显的十分重要。根据大部分资料的情况,本文采用了

19、最普遍使用的一种消抖同步电路,结构图如3.5所示。图3.5 常用消抖同步电路根据图3.4所示的各个模块。将各个模块描述如下:(1) 键输入模块复位键和开关键属于键输入模块。这些都是跑表基本的输入功能按键。(2) 时钟分频模块根据跑表要求的情况,用时钟分频模块来进行分频,已达到各种功能模块的需求。(3) 控制模块控制模块是由键输入模块导入信号,再由相应的程序功能分配相应的操作,从而执行相应的动作,已完成所要控制的对象。(4) 跑表计时模块由输入的控制键和时钟分频模块的参考,跑表就根据分频数据在键输入的命令下开始计时。(5) 跑表显示模块由了跑表计时模块的数据,数码管就可以根据提供的内容,将其展现

20、八个LED七段数码管显示上。3.4跑表的各个模块分析3.4.1键输入模块因为有抖动的缘故,会产生持续时间长短和不稳定的情况。因此才要在跑表电路中加上一个键输入模块来减少误差和抖动现象。键输入模块的作用就是保证系统能够扑捉到精确的脉冲,保证每一个脉冲都能够准确无误的被记录下来,从而能使它产生一个宽度为时钟周期模块的脉冲,保证时钟周期模块的正常读取。如图3-6所示它反映了开关脉冲on_off0的定时关系。图3.6 键输入模块中输入和输出信号的关系从图3.6 能看出:状态控制信号on_off_tmp1是开关信号on_off在时钟信号clk1的下降沿进行锁存的锁存信号;而状态控制信号tmp2是tmp1

21、在时钟信号clk1的下降沿进行的锁存信号;控制信号on_off_tmp3是状态控制信号on_off_tmp2的反相信号;开关脉冲就是时钟信号clk1、控制信号on_off_tmp1、控制信号on_off_tmp3的逻辑与。根据图3.6 所示的定时关系对该键输入模块进行VHDL描述,功能描述如下面源代码所示。源代码2library ieee;use ieee.std_logic_1164.all;entity keyin is port ( reset : in std_logic;on_off : in std_logic;clk : in std_logic;clk1 : in std_lo

22、gic;reset0 : out std_logic;on_off0 : out std_logic);end keyin;architecture rtl of keyin issignal on_off_tmp1 :std_logic;signal on_off_tmp2 :std_logic;signal on_off_tmp3 :std_logic;begin process(clk1) begin if ( clk1event and clk1 =0) then on_off_tmp2 = on_off_tmp1; on_off_tmp1 = on_off; on_off_tmp3

23、= not on_off_tmp2; end if; end process; process(clk) begin if ( clkevent and clk =0) then on_off0 = clk1 and on_off_tmp1 and on_off_tmp3; end if; end process;reset0 = reset; end rtl;图3.7 键入模块仿真波形3.4.2时钟分频模块分频模块的功能就是讲一个整的时钟信号进行分割,分割成时钟需要的那种频率。如消除抖动时钟信号为25Hz那么就要对时钟进行分配,分配给消除抖动电路一个25Hz的频率。跑表内部也需要定时信号,因

24、此,也要将时钟信号分配为一个是100Hz的时钟信号那么就可以对一个1000Hz的时钟进行10分频后得到100Hz,再将100Hz进行4分频就得到了25Hz了。在本设计中clk0是100Hz的时钟信号频率,clk1是一个25Hz的时钟频率。下面用语言来描述10分频电路和4分频电路。源代码3library ieee;use ieee.std_logic_1164.all;use ieee.std_logic_arith.all;use ieee.std_logic_unsigned.all;entity clk_div10 is port ( clk : in std_logic; reset :

25、 in std_logic;clk_div : out std_logic);end clk_div10;architecture rtl of clk_div10 is signal count :std_logic_vector (3 downto 0); begin process (clk) begin if ( clkevent and clk =1) then if ( reset = 1) then count 0); elsif ( count = “1001”) then count 0); else count = count +1; end if; end if; end

26、 process; process (clk) begin if ( clkevent and clk =1) then if ( count = “1001”) then clk_div = 1 ; else clk_div = 0 ; end if; end if; end process; end rtl;在上面的源代码中,第一步是将时钟信号进行了10分频,第二步将时钟信号进行了4分频。这里得到的4分频信号clk1与clk0相与,所以就得到了一个有效的脉冲为1ms的时钟信号。图3.8 分频模块仿真波形3.4.3控制模块控制模块主要就是控制跑表的开始、暂停与停止,以及清零和复位,还有加减键

27、的控制。控制模块主要的功能就是产生跑表的允许信号,这个模块的输入信号就是去除抖动后的信号,它还有启停信号、电源开关信号、内部计时信号。信号的时序关系如图3.9所示。图3.9 输入和输出信号的关系 根据上面的时序关系,不难写出控制模块的VHDL描述。控制模块的功能描述如源代码4所示。源代码4library ieee;use ieee.std_logic_1164.all;entity control is port ( sysreset : in std_logic; reset0 : in std_logic; on_off0 : in std_logic; clk0 : in std_log

28、ic; enable : out std_logic);end control;architecture rtl of control is signal strobe : std_logic;begin process (sysreset,reset0,on_off0) begin if (sysreset=1 or reset0 = 1) then strobe = 0; elsif (on_off0event and on_off0 = 1 ) then strobe = not strobe; end if; end process; enable = strobe;end rtl;图

29、3.10 控制模块仿真波形3.4.4跑表计时模块跑表计时模块主要就是面对跑表的计时工作,由系统分频来支配计时的工作,由控制电路的信号来安排跑表。计时模块有八个部分组成,它们分别是:小时十位信号、小时各位信号、分十位、分个位、秒十位、秒个位、秒0.1、秒0.01信号组成的。它是讲1个三进制计数器、5个十进制和2个六进制的计数器串连在一起的,从而来实现这个跑表计时模块的功能效果。由以上条件和功能形成的跑表的计时模块的结构框图如3.4所示。下面我们就要用源代码来描述一下三进制的、六进制的和十进制的计数器。源代码5library ieee;use ieee.std_logic_1164.all;use

30、 ieee.std_logic_arith.all;use ieee.std_logic_unsigned.all;entity count10 is port ( reset : in std_logic; enable : in std_logic; clk : in std_logic; cout : out std_logic; q : out std_logic_vector(3 downto 0);end count10;architecture rtl of count10 is signal q_tmp : std_logic_vector(3 downto 0);begin

31、process(clk) begin if (clkevent and clk =1) then if (reset = 1) then q_tmp 0); elsif (enable =1) then if (q_tmp =”1001”) then q_tmp 0); else q_tmp = q_tmp+1; end if; end if; end if; q = q_tmp; end process; cout = 1 when q_tmp =”1001” and enable =1 else 0;end rtl;图3.11 跑表计时模块的结构框图 在这些计时的VHDL语言描述中,用元件

32、形式调用计数器。但跑表的计时模块的VHDL源代码如下所示图3.12 计时模块仿真波形3.4.5跑表显示模块 跑表的理论上已经成立了,但要想供大家观测吸入信息,所以还是需要八个七段的LED显示数码管来展现给大家信息。跑表显示模块的结构框图如图3.13所示。图3.13 跑表显示模块的结构框图跑表的显示模块由count8、位选择电路、译码电路、位选择译码四个电路部分组成。下面就来描述一下显示模块的电路。首先描述的是八进制计数器count8,这个八进制计数器没有使能端口enable和进位输出端口cout,它的结构与计数器的结构基本上是相同的。它的电路VHDL语言的描述如源代码6所示。源代码6libra

33、ry ieee;use ieee.std_logic_1164.all;use ieee.std_logic_arith.all;use ieee.std_logic_unsigned.all;entity count8 is port ( reset : in std_logic;clk : in std_logic;sel : out std_logic_vector(2 downto 0);end count8;architecture rtl of count8 is signal sel_tmp : std_logic_vector(2 downto 0);begin process

34、(clk) begin if (clkevent and clk =1) then if (reset = 1) then sel_tmp 0); elsif (sel_tmp =”111”) then sel_tmp 0); else sel_tmp = sel_tmp+1; end if; end if; sel segment segment segment segment segment segment segment segment segment segment segment = “00000000”; end case; end process;end rtl;对跑表显示模块中

35、的四个子电路描述以后,就可以进行跑表显示模块的总体功能描述了。图3.15 显示模块仿真波形3.5仿真结果仿真步骤:(1) 建立一个波形编辑文件:File-NEW-Waveform Editor file;(2)鼠标指到左边区域,左键右键,选中;(3) List-移动管脚-OK,把仿真用的管脚调出来;(4)设定参数:Options-Grid size;File-End Time;View-Time range;(5)给定输入信号;(6)保存.scf文件;(7)MAX+Plus-simulator。仿真波形图如图3.16所示。3.16 跑表的仿真波形结 语毕业设计就要结束了,在整个研究设计的过程中

36、,我收获了许多许多。刚开始做毕业设计的时候是激情澎湃,把毕业设计想的很简单,以为跟以往的课程设计一样,随便写写就完事了,还准备速战速决解决掉论文。但是,刚开始做的时候就发现原来搞一项研究并不像想象的那样简单。刚开始做的时候就发现自己的知识漏洞好多,仅仅靠专业课本知识解决不了问题的,在着手之前还必须学习相关的知识。在硬件调试过程中,总是出现大量莫名其妙的错误和警告,有的要花费好长时间才能分析出来问题所在,还要去结合相关的知识去调试修改。当然,当看到自己所设计的跑表在精确地计时的时候还是很有成就感还是很欣慰的。 总之,本次毕业设计后让我真正体验到了科学研究中那种一丝不苟的严谨工作态度,使我掌握了对

37、VHDL硬件描述语言的熟练运用,培养了我采用理论联系实际的策略方法,提高了分析、解决计算机技术的实际问题的独立工作能力,能对数字跑表进行扩展,了解了科学研究与系统开发的整体分析的步骤,并能更熟练地运用MAX+plus 平台对设计进行编译、仿真,以及选用器件,完成系统的功能。通过本次设计,也使我的专业知识得到拓展,科研的素质得到提升,这些都将对我以后的学习和工作以及研究有很大的帮助。致 谢 毕业设计任务已经接近了尾声,这也标志着大学生活将要画上了句号。在这段时间里,我一直在老师的指导下从事毕业设计的学习和研究。经过一学期的辛勤努力,此次的毕业设计也到了收尾的阶段,毕业设计的成果是用来检验一个本科生的大学期间学习到的知识水平,由于经验的不足,在做毕业设计的时候总会有一些考虑不到的地方,所以如果没有指导老师的指点和传授经验,以及在同一时间做设计的同学们的帮助,想去很好的完成本次毕业设计是困难的。 在这里首先要感谢赵老师。虽然老师代的课程较多,工作较忙,但作为我的指导老师在做设计的过程中,包括从最开始查阅什么参考资料,到开始拟定毕业设计题目,然后编写开题报告和论

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 教案示例

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁