4位数字密码锁毕业设计.doc
《4位数字密码锁毕业设计.doc》由会员分享,可在线阅读,更多相关《4位数字密码锁毕业设计.doc(20页珍藏版)》请在三一办公上搜索。
1、华中科技大学文华学院毕业设计(论文)题目:4位数字密码锁设计(密码设置及验证电路)学 生 姓 名: 学号: 学 部 (系): 信息科学与技术学部 专 业 年 级: 08通信工程 指 导 教 师: 陈超原 职称或学位: 2012 年 05 月 31 日目录1绪论51.1设计内容51.2设计要求52 系统设计52.1 模块划分52.1 系统原理框图53功能模块的实现63.1时序电路63.2密码设置73.3密码输入73.4密码验证84软件仿真95数字逻辑系统简介105.1 Quartus II软件简介105.2硬件描述语言115.2.1 VHDL语言115.2.2 Verilog语言126 结论13
2、附录141时序电路142密码设置输入163密码验证17参考文献19谢辞20摘要:本设计利用FPGA作为核心控制板,用Verilog 硬件描述语言进行编程,利用计算机软硬件控制技术,设计一个基于FPGA的数字密码锁,能实现密码设定(如果密码没设定则默认密码为0000),密码输入及验证,当密码输入错误时报警或则指示灯亮;反之,密码输入正确时,另外一个指示灯亮。将程序下载到Altera公司的Cyclone系列目标芯片EP2C5T144C8上调试通过,并观察实际现象,满足设计要求。关键词:FPGA Verilog 数字密码锁AbstractThe design using the FPGA as th
3、e core of the control panel, Verilog hardware description language for programming, Computer hardware and software control technology, design an FPGA-based digital code lock, Set the password(if the password is not set then the default password is 000000), Password input and verification, Alarm or t
4、he light when the password input error; On the contrary, enter the correct password , a light. Program downloaded to the target chip EP2C5T144C8 Alteras Cyclone series through debugging , and to observe the actual phenomenon , to meet the design requirements.Keywords: FPGA Verilog Digital code lock引
5、 言随着人们生活水平的提高,如何实现家庭防盗这一问题也变得尤其的突出,传统的机械锁由于其构造的简单,被撬的事件屡见不鲜,电子锁由于其保密性高,使用灵活性好,安全系数高,受到了广大用户的青睐,电子密码锁的使用体现了人们消费水平、保安意识和科技水平的提高,而且避免了携带甚至丢失钥匙的麻烦。目前设计密码锁的方法很多,例如用传统的PCB板设计、用PLC设计或者用单片机设计等等。而用Verilog可以更加快速、灵活地设计出符合各种要求的密码锁,优于其他设计方法。Verilog是一种符合IEEE标准的硬件描述语言,其最大的特点是借鉴高级程序设计语言的功能特性,对电路的行为与结构进行高度抽象化、规范化的形式
6、描述,并对设计的不同层次、不同领域的模型验证与综合优化等处理,是设计过程延伸到高度自动化。1绪论1.1设计内容设计一个4位数字密码锁子系统1.2设计要求1、 能够预设4位密码;2、 具有密码输入及检测功能;3、 利用MAXplus对所设计的电路进行仿真并分析结果。2 系统设计本设计中,FPGA系统采用硬件描述语言Verilog按模块化方式进行设计,并将各模块集成于FPGA芯片中,然后通过Quartus II9.0软件开发平台对设计文件自动完成逻辑编译、逻辑化简、综合及优化、逻辑布局布线、逻辑仿真,最后对FPGA芯片进行编程,实现系统的设计要求。2.1 模块划分密码锁的的构成主要由密码输入、密码
7、设置,此外密码锁必须能够保存已设置的密码,因而需要一个寄存器来保存密码,同时由于控制电路和报警电路要用到不同的时钟,因而需要一个时序产生电路来生成需要的不同信号,采用分频方法实现。2.1 系统原理框图根据密码锁的电路特点,选用的是实验箱的模式6电路,根据电路功能,在这里设计的密码锁以4位2进制代码作为密码的电子密码锁。其原理框图如下图2.1所示:报警电路时序产生电路比较控制密码输入开锁信号寄存器(保存设置的密码)密码设置图2.1电子密码锁原理框图3功能模块的实现该模块主要是完成密码设置,密码输入,密码验证功能。3.1时序电路在密码锁的电路中,输入计时、报警计时需要的1HZ的时钟脉冲信号,而驱动
8、蜂鸣器工作需要的很高频率的脉冲信号,因而这里采用输入一个高频脉冲(1024HZ)信号来驱动蜂鸣器,采用分频的方法得到1HZ的计时脉冲。process(clk_1k) variable cnt1:integer:=0;beginif rising_edge(clk_1k) thenif cnt1=512 thenclk_1=not clk_1;cnt1:=0;else cnt1:=cnt1+1;end if;end if;end process;程序说明:clk_1k为输入的1024HZ高频脉冲,cnt为分频得到的1HZ计时脉冲。3.2密码设置为了安全性,密码锁必须能够重复的设定密码,在设定密码
9、锁后,应该设置一个寄存器来存储设定的密码。process(rst,password,enter_p) is beginif rst=0 thenif enter_p=1 thenram=password;en1=1;end if;end if;end process;程序说明:rst低电平时所有的模块复位,只有密码设置模块工作;password为设置密码时的输入端,ram就是存储密码的寄存器;enter_p为在这里为密码设置使能端,高电平有效。 密码设置的仿真波形如下图,由图中可以清楚地看到在enter_p高电平时寄存器ram中得到了输入的密码1001。3.3密码输入密码输入部分要求在密码开始
10、输入时进行计时,超时了要求报警,因此在密码输入时设置一个计时使能信号en2,密码开始输入时使能信号en2有效,控制电路的计时器开始计时;而且在密码确认键按下之前,电路不能对输入密码和已设置密码进行比较,因此需要设置一个寄存器,来存储输入的数据,当确认键按下时,就将寄存器里的数据送给控制部分进行比较。 process(rst,enter_c,en1,code) begin if rst=1 thenif en1=1 thenif enter_c=1 thencode_tmp=code;en2=1;end if; else code_tmp=0000;en2=0;end if; else code
11、_tmp=0000;en2=0;end if;end process;密码输入电路图如下图3.2 图3.1密码输入电路此密码输入电路使用74HC147 10线-4线优先编码器,由于147只有9个输入端,因此加入了数码0的按键,当输入端有键被按下时,输出端输出该键的BCD码的反码,并且GS/输出为0,代表有键被按下。GS/用于控制密码存储控制电路的移位。该电路有密码确认按键、密码修改按键和输入清除按钮,密码确认按键和密码修改按键的作用是密码输入完毕时,对控制电路的移位电路清零。密码确认按钮还接密码验证电路中的三态输出门,还连接密码验证电路中的JK触发器的清零端,用于对这个触发器的清零。输出清除按
12、键按下时本次输入清零。密码输入(修改)电路中的按键按下去都自动弹上来,也就是说按键只有被按下时才连接低电平,否则接高电平。3.4密码验证该模块中采用自定义存储器RAM进行密码的存储,主要使用case语句和if_else语句进行程序的衔接。密码验证电路图如下图3.2图3.2密码验证电路密码验证电路用16个异或门组成,每个异或门的输入来自密码存储电路的输入密码存储芯片和预设密码存储芯片,比较输入密码是否和预设密码相同,再加上与非门电路,判断全部输入是否为1,为1则表示输入正确,否则错误。密码输入电路中的确认按钮控制比较结果输出的三态门,输入四位密码后,按下确认键,验证后的结果输出至开锁报警电路。密
13、码修改按键连接JK触发器的CLK,修改密码流程是:输入预设密码按下修改密码按键输入新密码按下密码确认按键,修改结束。在输入新密码后在按下密码确认按键使JK触发器清零,清零后使得预设密码存储芯片不再存储输入密码。JK触发器的正向输出端接报警电路,如果密码输入错误就会报警。4软件仿真rst低电平时所有的模块复位,只有密码设置模块工作;password为设置密码时的输入端,ram就是存储密码的寄存器;enter_p为在这里为密码设置使能端,高电平有效。 密码设置的仿真波形如下图,由图中可以清楚地看到在enter_p高电平时寄存器ram中得到了输入的密码1001。图4.1密码设置仿真波形rst置高,设
14、置密码模块不工作,其他部分正常工作,en1为高时代表密码设置完毕,密码锁开始工作;enter_c是密码输入使能信号,高电平时表示开始密码输入,此时code_tmp中开始存储输入的数据,计时使能信号en2也变成高电平。 密码输入仿真波形如下,由图中可清楚的看到在enter_c为高时,寄存器code_tmp中存储了输入的数据code(系统仿真时有10ns的延时) 图4.2密码输入仿真波形5数字逻辑系统简介5.1 Quartus II软件简介Quartus II是Altera公司在221世纪初推出的可编程逻辑器件的集成开发软件,这个软件是该公司前一代可编程逻辑器件集成开发软件MAX+PLUS II的
15、更新换代产品。Quartus II集成开发软件支持可编程逻辑器件开发的整个过程,它提供一种与器件无关的设计环境。软件界面友好,使设计者能方便地进行设计输入、设计处理和器件编程。Quartus II集成开发软件提供了完整的多平台设计环境,能满足各种特定设计的需要。Quartus II设计工具支持VHDL、Verilog 硬件描述语言的设计流程。它也是在片可编程系统(System on a Programmable Chip, SOPC)的综合设计环境。另外,Quartus II集成开发软件也可以利用第三方软件的结果,并支持第三方软件的工作。为加快应用系统的开发,Quartus II集成开发软件包
16、含许多十分有用的参数化模块库(Library of Parameterized Modules, LPM),它们是复杂或高级系统构建的重要组成部分,在数字系统设计中被大量使用。当然这些模块也可以与用户设计文件一起使用。Altera提供的LPM函数均基于Altera公司器件的结构做了优化设计,在设计中合理地调用LPM不仅可以加快设计进程,还可以提高系统性能。有些LPM宏功能模块的使用必须依赖于一些Altera公司特定器件的硬件功能,如各类存储器模块、DSP模块、LVDS驱动器模块、PLL及SERDES和DDIO模块等,这在使用中需要注意。5.2硬件描述语言5.2.1 VHDL语言VHDL主要用于
17、描述数字系统的结构,行为,功能和接口。除了含有许多具有硬件特征的语句外,VHDL的语言形式和描述风格与句法是十分类似于一般的计算机高级语言。VHDL的程序结构特点是将一项工程设计,或称设计实体(可以是一个元件,一个电路模块或一个系统)分成外部(或称可视部分,及端口)和内部(或称不可视部分),既涉及实体的内部功能和算法完成部分。在对一个设计实体定义了外部界面后,一旦其内部开发完成后,其他的设计就可以直接调用这个实体。这种将设计实体分成内外部分的概念是VHDL系统设计的基本点。特点:VHDL 语言能够成为标准化的硬件描述语言并获得广泛应用,它自身必然具有很多其他硬件描述语言所不具备的优点。归纳起来
18、,VHDL 语言主要具有以下优点:(1) VHDL 语言功能强大,设计方式多样 VHDL 语言具有强大的语言结构,只需采用简单明确的VHDL语言程序就可以描述十分复杂的硬件电路。同时,它还具有多层次的电路设计描述功能。此外,VHDL 语言能够同时支持同步电路、异步电路和随机电路的设计实现,这是其他硬件描述语言所不能比拟的。VHDL 语言设计方法灵活多样,既支持自顶向下的设计方式,也支持自底向上的设计方法; 既支持模块化设计方法,也支持层次化设计方法。 (2) VHDL 语言具有强大的硬件描述能力 VHDL 语言具有多层次的电路设计描述功能,既可描述系统级电路,也可以描述门级电路;描述方式既可以
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数字 密码锁 毕业设计
链接地址:https://www.31ppt.com/p-3930599.html