密码锁设计VHDL源程序文档Word文档下载推荐.docx
- 文档编号:16154281
- 上传时间:2022-11-21
- 格式:DOCX
- 页数:23
- 大小:436.68KB
密码锁设计VHDL源程序文档Word文档下载推荐.docx
《密码锁设计VHDL源程序文档Word文档下载推荐.docx》由会员分享,可在线阅读,更多相关《密码锁设计VHDL源程序文档Word文档下载推荐.docx(23页珍藏版)》请在冰豆网上搜索。
CNT键盘消抖计数器
SIN1键盘按键键值寄存器
I键盘扫描计数器
DF1数字按键状态标志寄存器
ACC键盘数字输入暂存器
T报警计数器
REG电子密码锁密码存储器
NC计数器
1键盘输入扫描部分源程序
LIBRARYIEEE;
USEIEEE.STD_LOGIC_ARITH.ALL;
USEIEEE.STD_LOGIC_UNSIGNED.ALL;
USEIEEE.STD_LOGIC_1164.ALL;
ENTITYkbscan1is
PORT(clk:
inSTD_LOGIC;
kin:
inSTD_LOGIC_VECTOR(3DOWNTO0);
---PC7-PC4
kout:
outSTD_LOGIC_VECTOR(7downto0);
--PC3--PC
kout1:
outSTD_LOGIC_VECTOR(3downto0));
endkbscan1;
architectureaofkbscan1is
signalscans:
std_logic_vector(7downto0);
--PC7--PC0
signalscan:
std_logic_vector(3downto0);
--PC3--PC0
signalcnt:
integerrange0to140;
signalsin1:
std_logic_vector(3downto0);
signali:
integerrange0to3;
begin
scans<
=scan&
kin;
kout<
=scans;
kout1<
=scan;
process(clk)
if(falling_edge(clk))then
if(i=3)then
i<
=0;
else
=i+1;
endif;
caseiis
when0=>
scan<
="
0001"
;
when1=>
0010"
when2=>
0100"
when3=>
1000"
endcase;
endprocess;
Enda;
2键盘输入消抖部分源程序
ENTITYxiaodouis
Port(clk:
sin:
instd_logic_vector(7downto0);
sout:
outstd_logic_vector(7downto0));
endxiaodou;
architecturebehavioralofxiaodouis
integerrange0to120;
std_logic_vector(7downto0);
sin1<
=sin;
if(rising_edge(clk))then
if(sin1=sin)then
cnt<
=cnt+1;
if(cnt=120)then
sout<
endbehavioral;
3键盘输入编码部分源程序
ENTITYbianmais
lin:
inSTD_LOGIC_VECTOR(7DOWNTO0);
DF,FF:
outstd_logic;
nd,nf:
BUFFERstd_logic_vector(3downto0));
endbianma;
architecturebofbianmais
begin
process(clk)
ifclk'
eventandclk='
1'
then
caselinis
when"
10000001"
=>
ND<
0000"
--0
00010001"
--1
00010010"
--2
00010100"
0011"
--3
00100001"
--4
00100010"
0101"
--5
00100100"
0110"
--6
01000001"
0111"
--7
01000010"
--8
01000100"
1001"
--9
whenothers=>
1111"
ENDCASE;
ENDIF;
IFCLK'
EVENTANDCLK='
THEN
CASELINIS
00011000"
NF<
--qingchu
00101000"
--queren
01001000"
--shangsuo
10001000"
--kaisuo
10000100"
--wangjimima
10000010"
--genggaimima
Whenothers=>
ENDPROCESS;
DF<
=NOT(ND(3)ANDND
(2)ANDND
(1)ANDND(0));
FF<
=NF
(2)ORNF
(1)ORNF(0);
endb;
4电子密码锁的控制部分程序
DF数字按键标志寄存器
ENTITYkongzhiIS
PORT(CLK:
INSTD_LOGIC;
inSTD_LOGIC;
ND,NF:
inSTD_LOGIC_VECTOR(3downTO0);
LOCK,LOCK1,UNLOCK:
bufferSTD_LOGIC;
NULL1:
bufferSTD_LOGIC;
DATA:
outSTD_LOGIC_VECTOR(15downTO0));
ENDkongzhi;
ARCHITECTUREV1OFkongzhiIS
signali1:
signaldf1:
std_logic;
signalACC:
STD_LOGIC_VECTOR(15DOWNTO0);
signalt:
INTEGERRANGE0TO2;
signalREG:
STD_LOGIC_VECTOR(15downTO0);
signalNC,A:
INTEGERRANGE0TO3;
PROCESS(FF,DF)IS
BEGIN
ifrising_edge(clk)then
IFFF='
THEN
IFNF="
ACC<
0000000000000000"
NC<
ELSE
df1<
=df;
IFdf1='
0'
andDF='
IFNC<
4THEN
=ACC(11DOWNTO0)&
ND;
=NC+1;
REG<
=ACC;
LOCK<
='
UNLOCK<
LOCK1<
NULL1<
else
IFREG=ACCTHEN
LOCK<
UNLOCK<
IFt=2THEN
1000100010001000"
LOCK1<
lock<
unlock<
null1<
t<
=t+1;
NULL1<
IFUNLOCK='
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 密码锁 设计 VHDL 源程序 文档
![提示](https://static.bdocx.com/images/bang_tan.gif)