基于vhdl的交通灯控制器的设计与实现

基于vhdl的交通灯控制器的设计与实现

ID:15561342

大小:411.50 KB

页数:24页

时间:2018-08-04

基于vhdl的交通灯控制器的设计与实现_第1页
基于vhdl的交通灯控制器的设计与实现_第2页
基于vhdl的交通灯控制器的设计与实现_第3页
基于vhdl的交通灯控制器的设计与实现_第4页
基于vhdl的交通灯控制器的设计与实现_第5页
资源描述:

《基于vhdl的交通灯控制器的设计与实现》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、华中科技大学基于xilinxFPGA的VHDL交通灯控制器的设计--基于Spartan3E开发板专业:电子信息工程一.任务设计要求  ①设计一个十字路口交通信号灯的定时控制电路。要求红、绿灯按一定的规律亮和灭,并在亮灯期间进行倒计时,并将运行时间用数码管/液晶显示出来。  ②绿灯亮时,为该车道允许通行信号,红灯亮时,为该车道禁止通行信号。要求主干道每次通行时间为99秒,支干道每次通行时间为30秒。每次变换运行车道前绿灯闪烁,持续时间为5秒。即车道要由主干道转换为支干道时,主干道在通行时间只剩下5秒钟时,绿灯闪烁显示,支干道仍为红灯,以便主干道上已过停车线的车继续通行,未过停

2、车线的车停止通行。同理,当车道由支干道转换为主干道时,支干道绿灯闪烁显示5秒钟,主干道仍为红灯。③对红、绿灯的运行时间要能比较方便的进行重新设置。④对器件进行在系统编程和实验验证。⑤用VHDL语言对设计进行描述,设计一个测试方案,通过ISE对设计进行仿真验证。并能够下载到实验板上调试成功。任务扩展:在原设计的基础上加入指示方向的功能。二.系统设计1.系统原理图与说明由系统设计原理图,我以清楚地将系统分为六个模块:分频模块,时间设置模块,状态转换模块,时间计算模块,LED流水灯模块,LCD显示模块。1)分频模块分频模块其作用为:由于Spartan3E板上提供的时钟信号为50M

3、Hz,而设计所需时钟信号为1Hz,故使用分频模块将50MHz信号分频为1Hz信号。2)时间置数模块由于任务设计要求可以对主干道,支干道上左转、绿灯运行的时间进行重新设置调整,所以要对系统进行参数化设计。首先引入一组参数,main_gh,main_gl,main_lh,main_ll,branch_gh,branch_gl,branch_lh,branch_ll(下划线后面的字母分别取green,left,high,low首字母).需要置数时,首先选择对主干道还是支干道时间置数,这里设置一个main_or_branch参数,当main_or_branch为高时设置支干道时间,

4、为低时设置主干道时间。置数时,通过s_set_button,l_set_button对时间进行设置,具体方法参见代码。为了置数方便,引入一个add_or_decent参数,低电平时按下button可以增计数,高电平时按下可以减计数。3)状态转换模块状态转化模块是整个系统的核心模块它控制整个交通灯系统的状态变化,整个过程划分为四个基本状态:主干道绿灯、主干道左转、支干道绿灯、支干道左转,用state、s_or_l为00、01、10、11来代表。每当一个状态的计数器为00时,state、s_or_l发生改变,以实现状态间的转换,进而控制交通灯的变化。4)时间计算模块这次设计中扩

5、展了左转向的功能,因此红灯时间不仅仅是另一干道的直行时间,而是直行时间和左转时间之和。5)LCD显示模块Spartan3E板上只有LCD显示模块,所以采用此模块显示当前亮灯的剩余时间和设置时间模块的时间显示。通过输入counterplay_1l,counterplay_1h,counterplay_2l,counterplay_2h四位二进制数,加上0011显示成十进制数,分别代表两位数的低位和高位6)LED显示模块由输入信号state、s_or_l、flash,分别取000,001,010,011,100,101,110,111所得到的main_green,main_le

6、ft,main_red,branch_left,branch_green,branch_red的不同值,来控制主干道,支干道红绿左转灯的亮灭。其中1表示亮,0表示灭。如表3-1所示。由上表可得到:main_green<=NOT(state)ANDNOT(s_or_l)AND(NOT((flashANDclk)));main_left<=NOT(state)ANDs_or_lAND(NOT((flashANDclk)));main_red<=state;branch_green<=stateANDNOT(s_or_l)AND(NOT((flashANDclk)));branc

7、h_left<=stateANDs_or_lAND(NOT((flashANDclk)));branch_red<=NOT(state);2.输入输出设计任务设计开发板基于Spartan3E板,具体输入输出设定如下:1)输入:开关:main_or_branch:设置主干道还是支干道EN:使能信号run_or_set:设置运行模式还是时间设置模式add_or_decent:置数模式:增加或者减少按键:s_set_button:直行时间设置按键l_set_button:左转时间设置按钮时钟:clk2)输出:LCD显示屏

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。