EDA课程设计---交通灯控制器的设计

上传人:re****.1 文档编号:489132328 上传时间:2023-03-12 格式:DOC 页数:9 大小:133KB
返回 下载 相关 举报
EDA课程设计---交通灯控制器的设计_第1页
第1页 / 共9页
EDA课程设计---交通灯控制器的设计_第2页
第2页 / 共9页
EDA课程设计---交通灯控制器的设计_第3页
第3页 / 共9页
EDA课程设计---交通灯控制器的设计_第4页
第4页 / 共9页
EDA课程设计---交通灯控制器的设计_第5页
第5页 / 共9页
点击查看更多>>
资源描述

《EDA课程设计---交通灯控制器的设计》由会员分享,可在线阅读,更多相关《EDA课程设计---交通灯控制器的设计(9页珍藏版)》请在金锄头文库上搜索。

1、EDA课程设计 题目: 交通灯控制器的设计 学院: 信息科学技术学院 专业: 电子信息工程 姓名: 同组: 指导老师: 龙翔 一、 设计题目交通灯控制器的设计二、 设计功能:实现高速公路与乡间小路的交叉路口红绿灯的控制三、具体功能要求: 1、只有在小路上发现汽车时,高速公路上的交通灯才可能变成红灯。 2、当汽车行驶在小路上时,小路的交通灯保持为绿灯,但不能超过给定的延迟时间。 (注:这段时间定义为20秒时间) 3、高速公路灯转为绿灯后,即使小路上有汽车出现,而高速公路上并无汽车,也将在给定时间内保持高速公路绿灯。 (注:这段时间定义为60秒时间)4、交通信号灯的4种状态如下表:ABCD高速交通

2、灯绿(60秒)黄(5秒)红(20秒)红(5秒)小道交通灯红红绿黄四,设计思路根据交通信号灯的变化可以有四种状态,分别为A,B,C,D输入为XLB即判断小路是否有车,当小路有车时再判断此时大路的绿灯状态,如果绿灯的状态还没结束,那么小路此时为红色,当高速路60s结束后在经过5s的黄灯,在跳转到C状态即小路变为绿灯,大路变为红灯,当小路20s过后再经过5s的黄灯跳转到D状态,大路变为绿灯小路变为红灯,采用赋值的方法来计数,当计数到想要值得时候在令CLR清零,状态也是采用赋值的方法实现不同状态的变化。各输入端口和输出端口及变量信号的说明:输入端CLKXLB意义时钟信号小路是否有车输出端GSRGSYG

3、SGXLRXLYXLG意义高速红灯高速黄灯高速绿灯小路红灯小路黄灯小路绿灯变量或信号CLRS意义清零变量计时变量五,源程序的设计LIBRARY IEEE; USE IEEE.STD_LOGIC_1164.ALL;USE IEEE.STD_LOGIC_UNSIGNED.ALL;ENTITY JTDKZ IS PORT(CLK:IN STD_LOGIC; XLB:IN STD_LOGIC; GSR,GSY,GSG,XLR,XLY,XLG:OUT STD_LOGIC); END ENTITY JTDKZ;ARCHITECTURE ART OF JTDKZ ISTYPE STATE_TYPE IS(A

4、,B,C,D); SIGNAL STATE:STATE_TYPE; BEGIN CNT:PROCESS(CLK) ISVARIABLE CLR:BIT;-在进程中定义变量CLR(CLR=0:计时清零) VARIABLE S:STD_LOGIC_VECTOR(0 TO 5); -在进程中定义变量S(S为时钟计时器)BEGINIF(CLKEVENT AND CLK=1)THEN-判断时钟信号上升沿IF CLR=0THEN-当CLR=0时计时变量清零S:=000000;ELSES:=S+1;END IF;CASE STATE IS-状态A为大路通车(绿灯),小路禁止通车(红灯)WHEN A=GSR=

5、0;GSY=0;GSG=1; BR=1;BY=0;BG=0; IF(XLB=1) THEN-判断小路是否有车 IF(S=111011) THEN-判断大路通行是否满60秒 STATE=B;CLR:=0; -大路满60秒,计时清零,转到状态B ELSE STATE=A;CLR:=1;-大路不满60秒,继续状态A END IF; ELSE STATEGSR=0;GSY=1;GSG=0; XLR=1;XLY=0;XLG=0;IF S=000100 THEN-判断大路黄灯是否满5秒 STATE=C;CLR:=0;-满5秒,计时清零,跳转到C状态ELSE STATEGSR=1;GSY=0;GSG=0;

6、XLR=0;XLY=0;XLG=1; IF (XLB=1)THEN-判断小路是否有车 IF S=010011 THEN-判断大路通行是否满20秒STATE=D;CLR:=0;-满20秒,计时清零,跳转到D状态 ELSE STATE=C;CLR:=1;-不满20秒继续状态C。 END IF;ELSIF XLB=0 THEN-判断小路是否有车 STATE=D;CLR:=0;-小路没车,跳转到状态D ELSESTATEGSR=1;GSY=0;GSG=0;XLR=0;XLY=1;XLG=0;IF S=000100 THEN-判断小路黄灯是否满5秒STATE=A;CLR:=0;-满5秒,计时清零,跳转到

7、A状态ELSE STATE=D;CLR:=1;-不满5秒,继续状态DEND IF;END CASE;-结束CASE 语句 END IF;END PROCESS CNT;-结束进程语句END ARCHITECTURE ART;-结束结构体语句五、对源程序进行编译及仿真1,当小路一直没车时即XLB一直为0,可以看到XLR一直为高电平即小路一直是红灯,大路GSG一直为高电平即大路一直为绿灯。2,当小路一直有车即XLB一直为1时,可以看到在前60s内小路为红灯,大路为绿灯,当大路绿灯60s完后因为小路有车了,此时状态发生变化,可以看到大路由绿灯变为黄灯小路还是红灯,5s黄灯过后可以看到状态又发生变化,

8、小路变为绿灯大路变为了红灯,当满20s后状态又发生变化小路变为黄灯,大路还是红灯,5s后大路变为了绿灯,小路变为红灯。3,当给定任意XLB输入时可以看到,在前60s内不管小路是否有车,大路一直为绿灯,小路一直为红灯。当过了60s后发现小路上有车则跳到了状态1,此时大路为黄灯,小路为红灯,经过5s的黄灯后又会跳到状态2,此时大路为红灯小路为绿灯,经过20s的绿灯后又发现跳到了状态3,此时大路为红灯,小路为黄灯,经过5s的黄灯后有跳到状态0此时的大路为绿灯小路又变成了红灯。六,心得体会 本次课程设计,通过我与本组成员一起的努力,终于做出了交通信号灯。也使我们进一步加深了对电子设计自动化的了解,并进

9、一步熟练了对maxplus2软件的操作。期间我们遇到了一些问题,我们通过查阅课本和其他资料、互相讨论,终于在不断修改后完成交通灯的设计。经过这次的课程设计我感觉到了合作的重要性同时发现了自己的问题。那就是理论与实际相结合是很重要的,只有理论知识是远远不够的,只有把所学的理论知识和实践相结合起来,从理论中得出结论,才能真正为社会服务,从而提高自己的实际动手能力和独立思考的能力。在设计中遇到问题,可以说是困难重重,但这也是以后我们所必须面对的,我们要从中学会处理问题的方式,及更牢靠的掌握知识。总的来说,这次设计交通灯积累了经验和增强了实验素养,受益匪浅。在这里对我们的指导老师表示衷心的感谢!七、参考文献数字电子技术基本教程 阎 石主编 清华大学出版社电子技术基础实验 侯建军主编 高等教育出版社数字电子技术与设计 高仁璟主编 大连理工大学出版社VHDL与复杂数字系统设计 金西 主编 西安电子科技大学出版社

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

当前位置:首页 > 商业/管理/HR > 商业计划书

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号