FPGA_交通灯控制程序设计.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
FPGA_交通灯控制程序设计

实验三 交通灯控制程序设计 实验目的和要求 完成交通灯控制器的设计,掌握状态机的使用。 2.实验内容或原理 根据交通灯的工作方式,设计的交通灯由两组红绿灯信号控制四组交通灯,其中处于同一个方向的交通灯共用一组红绿灯信号。显示顺序为:方向一为黄灯、红灯、绿灯,方向二为绿灯、黄灯,红灯。‘0’表示灯亮,‘1’表示灯熄。其中绿灯,黄灯,红灯的持续时间分别为25秒,5秒,20秒。系统框图如图2所示,系统包括分频模块及信号灯模块。分频模块对系统时钟进行秒分频,为信号灯提供秒输入信号;信号灯模块实现交通灯控制的逻辑功能。 交通灯控制器的设计方案 设东西方向和南北方向的车流量大致相同,因此红、绿、黄灯的时长也相同,定为红灯20秒,绿灯25秒,黄灯5秒,同时用数码管指示当前状态(红、绿、黄灯)剩余时间。 方案一:采用VHDL语言直接编写,实现交通灯指挥功能。 方案二:采用模块层次化设计,将此设计分为四个模块:计时模块,状态控制模块,信号灯显示模块,数码扫描显示模块。将四个模块再分别用VHDL语言编写成,做成原理图模块,用原理图输入法做整个设计的顶层文件。 交通灯原理分析 当SPC = 1时,数码管停止计时,S输出为B010010,即南北、东西方向指示灯示数维持不变。 当SPC=‘1’跳变到SPC=‘0’时,数码管继续计时,恢复正常工作状态。 当SPC = 0时,交通即开始正常工作。R=‘1’时,进入初始状态S0=001010经过20秒,变为S1=100010再经过5秒,变为S2=010001,再经过20秒,变为S3=010100,再经过5秒,S变为B001010……如此循环下去。 南北、东西方向的红绿灯按表一表二变化。 表一 交通灯状态转换表 东西(A)方向 黄灯 红灯 红灯 绿灯 绿灯 黄灯 5秒 20秒 25秒 5秒 南北(B)方向 绿灯 黄灯 绿灯 黄灯 红灯 红灯 25秒 5秒 5 20秒 表二 交通灯状态转换表 SPC S 备注 1 010010 指示灯示数维持不变 0 S0:001010 持续5秒,转到S1 S1:100010 持续20秒,转到S2 S2:010001 持续5秒,转到S3 S3:010100 持续20秒,转到S0 注:S的六位分别对应东西方向(A方向)的红绿黄和南北方向(B方向)的红绿黄。‘1’表示亮,‘0’表示灭。 5.VHDL仿真实验 (1)为此工程新建一个文件夹。启动QuartusII软件工作平台,新建工程设计文件名为traffic.vhd。在新建的VHDL模型窗口下编写源程序代码如下: LIBRARY IEEE; USE IEEE.STD_LOGIC_1164.ALL; USE IEEE.STD_LOGIC_UNSIGNED.ALL; USE IEEE.STD_LOGIC_ARITH; ENTITY traffic IS PORT (CLK,R,SPC: IN STD_LOGIC; LIGHT : OUT STD_LOGIC_VECTOR(5 DOWNTO 0); Q1,Q2 : OUT INTEGER RANGE 0 TO 25; LED1,LED2,LED3,LED4 :OUT STD_LOGIC_VECTOR(3 DOWNTO 0)); END traffic ; ARCHITECTURE behav OF traffic IS TYPE STATES IS (S0,S1,S2,S3); SIGNAL STATE : STATES ; SIGNAL T1,T2: INTEGER RANGE 0 TO 25; SIGNAL L1,L2,L3,L4 : INTEGER RANGE 0 TO 9; BEGIN P1: PROCESS (CLK,STATE) BEGIN IF R=1THEN STATE=S0;T1=20;T2=25; ELSIF SPC=1 THEN LIGHT=010010; ELSIF CLKEVENT AND CLK=1 THEN CASE STATE IS WHEN S0= LIGHT=100010; T1=T1-1;T2=T2-1; Q1=T1;Q2=T2; IF T1=0 THEN STATE=S1;T1=5;T2=5; END IF; WHEN S1

文档评论(0)

shenlan118 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档