基于VerilogHDL语言的复杂交通指标灯设计与实现

合集下载

基于VerilogHDL语言的复杂交通指标灯设计与实现

基于VerilogHDL语言的复杂交通指标灯设计与实现

2009.2011.141引言针对采用单片机和可编程控制器PLC 实现交通灯控制器的不足,如:存在修改、调试均需要硬件电路支持,且存在采用的电路原件相对较多、接线复杂、故障率高、可靠性低等不足[1,2]。

尽管文献[3,4]的作者在实时性和自适应控制系统设计方面展开了研究,但其依赖硬件电路支持的不足仍然存在。

为此,研究者和工程师们寻求其他设计交通灯控制器的途径,而随着Electronic Design Automation 技术的发展,在线可编程逻辑器件PLD 的出现,使得用户在实验室制作专用集成电路成了现实。

研究者提出了一些基于VHDL 的交通灯控制器的设计方案[5-8],有效地克服了基于PLC 交通灯设计与实现方案的不足,其中,HDL (Hardware Description Language ,硬件描述语言)是一种描述硬件工作的语言。

Verilog HDL 是工业和学术界的硬件设计者常用的两种主要的HDL 之一。

文献[6]的作者依据Altera 公司的EDA 软件平台Max+PlusII ,给出CPLD 芯片上交通灯系统的控制过程的实现,而文献[8]的作者选择XILINX 公司的FPGA 芯片(如同文献[7]的设计工作),采用ISE5.X 和MODELSIMSE6.0开发工具进行了程序的编译和功能仿真。

2交通灯系统控制器的设计与实现2.1设计要求无论采用何种手段进行交通灯控制器的设计,交通灯控制器均遵循类似的工作机制,借用文献[5-8]的设计思路,按照以下规则对系统进行控制:(1)十字路口的A 方向(主干道)、B 方向(支干道)各设红(R),黄(Y),绿(G)和左拐(L),右拐(R )五盏灯,A 方向4种灯按“绿黄左黄红黄”的顺序循环亮灭,B 方向4种灯按“红黄绿黄左黄”的顺序循环亮灭,并能将灯亮的时间以倒计时的形式显示出来。

(2)保证主干道绝对优先,初始状态设为主干道绿灯,支干道红灯。

(3)两个方向各种灯亮的时间应该能够非常方便地进行设置和修改,此外设A 方向是主干路,车流量大,因此A 方向通行的时间在正常模式下比B 方向时间长一些。

基于VerilogHDL的交通灯控制器设计

基于VerilogHDL的交通灯控制器设计

目录第一章设计原理 (1)1.1设计要求 (1)1.2设计思路和原理 (1)1.3实现方法 (1)第二章Verilog 程序设计 (2)2.1整体设计 (2)2.2 具体设计 (3)第三章仿真 (7)3.1 波形仿真 (7)第四章设计总结 (9)4.1 总结 (9)4.2参考资料 (9)程序清单 (10)交通灯控制器设计第一章 设计原理1.1设计要求设计一个交通控制器,用LED 显示灯表示交通状态,并以7段数码显示器显示当前状态剩余秒数 主干道绿灯亮时,支干道红灯亮;反之亦然,二者交替允许通行,主干道每次放行35s ,支干道每次放行25s 。

每次由绿灯变为红灯的过程中,亮光的黄灯作为过渡,黄灯的时间为5s 。

能进行特殊状态显示,特殊状态时东西、南北路口均显示红灯状态。

用LED 灯显示倒计时,并且能实现总体清零功能,计数器由初始状态开始计数,对应状态的显示灯亮。

1.2设计思路和原理本次设计是针对十字路口,进行南北和东西直行情况下交通灯控制。

设定东西方向为主干道方向,根据交通灯的亮的规则,在初始状态下四个方向的都为红灯亮启,进入正常工作状态后,当主干道上绿灯亮时,支干道上红灯亮,持续35S 后,主干道和支干道上的黄灯都亮启,持续5S 后,主干道上红灯亮启,支干道上绿灯亮启持续25S ,之后主干道和支干道上的黄灯都亮启5s ,一个循环完成。

循环往复的直行这个过程。

其过程如下图所示:0s30s25s主干道方向支干道方向图1.交通灯点亮时间控制说明1.3实现方法本次采用文本编辑法,即利用Verilog 语言描述交通控制器,通过状态机计数法,实现设计所要求的交通灯控制及时间显示。

设计中用两组红黄绿LED 模拟两个方向上的交通灯,用4个7段数码管分别显示两个方向上的交通灯剩余时间,控制时钟由试验箱上频率信号提供。

第二章 Verilog 程序设计2.1整体设计根据上章设计原理,交通灯控制的关键是各个状态之间的转换和进行适当的时间延时,根据状态机的设计规范,本次设计了三个状态之间的循环转化,其真值表及状态转化图如下所示:状状状状状状状状状状状状00状状10状状11状状01状状状状状状状状状状状状状状状状状状状状状状状状状状状状状状状状状状状状状状状状001100010010001010100010图2.交通灯控制状态转化说明:该状态图为交通灯在正常情况下的状态转化图,进入控制后,状态00时主干道绿灯及支干道红灯亮起,进入状态01后两路黄灯亮起,状态11时主干道红灯及支干道绿灯亮起。

基于Verilog HDL的交通灯控制器

基于Verilog HDL的交通灯控制器

交通灯控制器专业:电子信息科学与技术_班级:学号:学生姓名:指导教师:*** _摘要交通灯是城市交通监管系统的重要组成部分,对于保证机动车辆的安全运行,维持城市道路的顺畅起到了重要作用。

目前很多城市交叉路口的交通灯实行的是定时控制,灯亮的时间是预先设定好的,在时间和空间方面的应变性能较差,一定程度上造成了交通资源的浪费,加重了道路交通压力。

本文在EDA技术的基础上,利用FPGA的相关知识设计了交通灯控制系统,可以根据实际情况对灯亮时间进行自由调整,通过数码管显示等待时间,点阵显示运行状态,蜂鸣器提示紧急状况,很好地维护了道路的交通规则。

整个设计系统通过Quartus Ⅱ软件中的Verilog HDL语言进行代码编写,并下载到FPGA器件中进行硬件调试,验证了设计的交通信号灯控制电路完全可以实现预定的功能,具有一定的实用性。

关键字:交通灯、定时控制、FPGA、Verilog HDL一、设计原理根据交通灯循环顺序表可以得到如表1的循环状态表,遇到紧急状况的时候,这时候有东西通行、南北通行和全部禁行三种情况,紧急状态结束后条件满足的情况下状态依次往后跳转。

表1 交通灯循环状态表1. 方案比较方案一:直接用GPIO口驱动双色点阵;方案二:用两块3-8译码器控制双色点阵,一个控制红色,另一个控制绿色;方案三:用一块4-16选择器控制双色点阵;通过比较方案一需要24个GPIO,方案二需要14个GPIO口,而方案三只需要12个GPIO 口,考虑到IO口的数量限制和资源的优化,故选择方案三,硬件部分还包括Led灯和蜂鸣器,用洞洞板搭建好了硬件电路。

2.系统框架图1 状态机状态转换图随着现代生活节奏的加快,人们出门便更多地选择自家的交通工具,这无疑加大了交通流量,如何控制十字路口的红绿灯,便显得相当的重要。

简单的,有效地控制红绿灯,是减小客流量,甚至减少交通事故的重要保障。

而此次课题,我选择了交通灯控制电路,能熟悉Verilog HDL 硬件描述语言在现实生活中的重要意义,为以后的学习和工作打好基础。

EDA实验报告:基于VHDL语言的交通灯控制系统设计与实现

EDA实验报告:基于VHDL语言的交通灯控制系统设计与实现
(k1=0)
图为k1=0时的输出状态s1,输出恒为011110。即亮灯为R1,y2。保持时间1S。
(k2=0)
上图为k2=0时的输出状态s2,输出恒为101011。即亮灯为G1,R2。保持时间2S。
(k3=0)
上图为k3=0时的输出状态s3,输出恒为110011。即亮灯为R1,G2。保持时间1S。
四、小结及心得体会
else
if counter<5 then
next_state<=s3;
else
next_state<=s0;
end if;
end if;
end if;
end if;
end if;
end case;
end process;
ouput:process(current_state)
begin ——显示程序
begin
u1: jiaotongdeng port map(
clk=>clki,
k0=>k0,
k1=>k1,
k2=>k2,
k3=>k3,
r1=>r1,r2=>r2,g1=>g1,g2=>g2,y1=>y1,y2=>y2
);
u2: div port map(clk=>clk1,clk_out=>clki);
end if;
end if;
end if;
when s3=>
if k0='0' then
next_state<=s0;
else
if k1='0' then
next_state<=s1;

基于Verilog HDL语言的带左转复杂交通灯设计

基于Verilog HDL语言的带左转复杂交通灯设计

基于Verilog HDL语言的带左转复杂交通灯设计1 引言EDA技术是依靠功能强大的电子计算机,在EDA工具软件平台上,对以硬件描述语言HDL(Hardware Description Language)为系统逻辑描述手段完成的设计文件,自动地完成逻辑编辑、化简、分割、综合、优化和仿真,直至下载到可编程逻辑器件CPLD/FPGA或专用集成电路ASIC(Application Specific Integrated Circuit)芯片中,实现既定的电子电路设计功能。

EDA技术使得电子电路设计者的工作仅限于利用硬件描述语言和EDA软件平台来完成对系统硬件功能的实现,极大地提高了设计效率,缩短了设计周期,节省了设计成本。

实现路口交通灯系统的控制方法很多,可以用标准逻辑器件,可编程控制器PLC,单片机等方案来实现。

但是这些控制方法的功能修改及调试都需要硬件电路的支持,在一定程度上增加了功能修改及系统调试的困难。

因此,在设计中采用EDA技术,应用目前广泛应用的Verilog HDL硬件电路描述语言,实现交通灯系统控制器的设计,利用MAX+PLUS 集成开发环境进行综合、仿真,并下载到CPLD可编程逻辑器件中,完成系统的控制作用。

2 Verilog HDL硬件描述语言的介绍Verilog HDL是目前应用最广泛的一种硬件描述语言。

Verilog HDL是在1983年由GDA(GateWay Design Automation)公司的Phil Moorby首创的。

1986年,他对Verilog HDL 的发展又作出了另一个巨大贡献:提出了用于快速门级仿真的XL算法。

Verilog-XL算法的成功,使Verilog HDL语言得到迅速发展。

基于Verilog HDL的优越性,IEEE于1995年制定了Verilog HDL 的IEEE标准,即Verilog HDL1364-1995。

Verilog HDL语言具有以下特点:基本逻辑门,例如and,or和nand等都内置在语言中。

EDA课程设计-用VerilogHDL语言编写-红绿灯控制程序

EDA课程设计-用VerilogHDL语言编写-红绿灯控制程序

XI’AN UNIVERSITY OF TECHNOLOGYEDA综合实践]所在院系自动化与信息工程学院专业名称电子信息科学与技术《班级电技111题目红绿灯设计指导教师XXXX成员XXX-2014年元月成绩:3、报告评语及成绩(30%):二、<三、红绿灯原理及设计思路设计思路:为了实现两个方向红绿灯循环亮灭的过程,假设该过程如下:起始(st0)东西方向绿灯亮(green1=1),南北方向红灯亮(red2=1),这个过程持续3个clock周期;然后(st3)东西方向黄灯亮,绿灯灭,南北方向红灯仍然亮着,这个过程持续1个clock;然后(st4)东西方向红灯亮,南北方向绿灯亮,这个过程持续3个clock;然后南北(st7)方向黄灯亮,东西方向红灯仍然亮着,这个过程持续一个clock;接下来就回到起始(st0)的状态进行循环。

此程序中无论哪个方向,各个灯亮着的时间之比为, 绿:黄:红=3:1:4,可以设置clock的值确定各灯具体的亮的时间。

1、红绿灯工作状态的真值表:2、;3、模型图:(见下页)3状态机:(三、源程序module traffic(clock,reset,red1,yellow1,green1,red2,yellow2,green2); input clock,reset;output red1,yellow1,green1,red2,yellow2,green2;parameter st0=0,st1=1,st2=2,st3=3,st4=4,st5=5,st6=6,st7=7;reg[2:0] state,nxstate;|reg red1,yellow1,green1,red2,yellow2,green2;always(posedge clock or posedge reset)beginif(reset)state=st0;elsestate=nxstate;$endalways(state)beginred1=1'b0; yellow1=1'b0; green1=1'b0;red2=1'b0; yellow2=1'b0; green2=1'b0;case(state)st0:begingreen1=1'b1;<red2=1'b1;nxstate=st1;endst1:begingreen1=1'b1;red2=1'b1;nxstate=st2;%endst2:begingreen1=1'b1; red2=1'b1;nxstate=st3; endst3:begingreen1=1'b0; [yellow1=1'b1; red2=1'b1;nxstate=st4; endst4:beginred1=1'b1;red2=1'b0;yellow1=1'b0;¥green2=1'b1; nxstate=st5; endst5:beginred1=1'b1;green2=1'b1; nxstate=st6; end、st6:beginred1=1'b1;green2=1'b1; nxstate=st7; endst7:begingreen2=1'b0;red1=1'b1;>yellow2=1'b1;nxstate=st0;endendcaseendendmodule四、编译和仿真波形红绿灯设计仿真图五、仿真分析及结论根据仿真波形图可以看出实验结果符合预期设想,基本实现了红绿黄灯按一定规律进行循环闪烁的功能,仿真结果与预想的一致,实现了各个方向绿、黄、红灯闪亮的时间比为3:1:4。

毕业设计---基于Verilog的交通灯控制器的设计

毕业设计---基于Verilog的交通灯控制器的设计

课题:交通灯控制器的设计目录1. 设计内容与要求 (2)2. 交通灯控制系统的组成框图 (3)3. 交通灯控制电路的设计 (4)4. 交通灯控制电路设计的难点与解决方法 (5)5. 交通灯控制电路的Verilog语句 (6)5. 交通灯控制电路的程序和波形分析 (12)6. EPF10K10LC84-4芯片引脚分配图 (20)7. 实验小结 (21)一、 设计内容与要求① 设计一个十字路口交通信号灯的定时控制电路。

要求红、绿灯按一定的规律亮和灭,并在亮灯期间进行倒计时,并将运行时间用数码管显示出来。

②绿灯亮时,为该车道允许通行信号,红灯亮时,为该车道禁止通行信号。

要求主干道每次通行时间为99秒,支干道每次通行时间为30秒。

每次变换运行车道前绿灯闪烁,持续时间为5秒。

即车道要由主干道转换为支干道时,主干道在通行时间只剩下5秒钟时,绿灯闪烁显示,支干道仍为红灯,以便主干道上已过停车线的车继续通行,未过停车线的车停止通行。

同理,当车道由支干道转换为主干道时,支干道绿灯闪烁显示5秒钟,主干道仍为红灯。

③ 对红、绿灯的运行时间要能比较方便的进行重新设置。

④ 添加左转灯的控制,可自行到实际十字路口观看规律并实现。

对器件进行在系统编程和实验验证。

⑤用Verilog 语言对设计进行描述,设计一个测试方案,通过Muxplus 对设计进行仿真验证。

并能够下载到实验板上调试成功。

二、交通灯控制系统的组成框图交通信号灯控制原理图绿灯左拐灯红灯绿灯左拐灯红灯交通信号灯控制系统框图三、交通灯控制电路的设计交通灯控制器设计的重点是控制电路的设计,根据设计要求分析,控制电路的算法可用下图所示的ASM图描述。

各状态的详细说明如下:S0状态:主干道绿灯亮,支干道红灯亮,此时若主干道有车等待左拐,而且主干道绿灯已亮足规定的时间间隔Ts;在主干道绿灯亮了(Ts-5)s后,则开始闪亮,直至绿灯亮了Ts;控制器发出状态转换信号Tempm==0,输出从状态S0转换到S1。

verilog HDL课程设计之交通灯控制电路

verilog HDL课程设计之交通灯控制电路

课程设计任务书(理工科类)Ⅰ、课程设计(报告)题目:《HDL项目设计》交通灯控制电路Ⅱ、课程设计(论文)工作内容一、课程设计目标1、培养综合运用知识和独立开展实践创新的能力;2、《硬件描述语言》是一门技术性、应用性很强的学科,实验课教学是它的一个极为重要的环节。

不论理论学习还是实际应用,都离不开实验课教学。

如果不在切实认真地抓好学生的实践技能的锻炼上下功夫,单凭课堂理论课学习,势必出现理论与实践脱节、学习与应用脱节的局面。

《HDL项目设计》的目的就是让同学们在理论学习的基础上,通过完成一个涉及时序逻辑、组合逻辑、声光输出的,具有实用性、趣味性的小系统设计,使学生不但能够将课堂上学到的理论知识与实际应用结合起来,而且能够对分析、解决实际的数字电路问题进一步加深认识,为今后能够独立进行某些数字应用系统的开发设计工作打下一定的基础。

二、研究方法及手段应用1、将任务分成若干模块,查阅相关论文资料,分模块调试和完成任务;2、通过EDA实验箱进行实际调试,实现软件的功能。

三、课程设计预期效果1、完成实验环境搭建;2、(1)设计一个十字路口的交通灯控制电路,每条路配有红、黄、绿交通信号灯,通过电路对十字路口的两组交通灯的状态实现自动循环控制;(2)实现东西车道和南北车道上的车辆交替运行,每次通行时间为20秒;(3)要求黄灯亮3秒后,红灯才能转为绿灯,黄灯亮时要每秒闪亮一次;(4)东西车道和南北车道每次通行的时间不同且可调。

学生姓名:专业年级:摘要本次课程设计通过HDL技术设计交通灯控制系统,其设计描述可被不同的工具所支持,可用不同器件来实现。

利用Verilog HDL语言自顶向下的设计方法设计交通灯控制系统,使其实现道路交通的快速正常运转,突出了其作为硬件描述语言的良好的可读性、可移植性和易理解等优点,并通过Quartus II和ModelSim完成综合、仿真。

此程序下载到FPGA芯片后,可应用于实际的交通灯控制系统中。

VerilogHDL编写的交通灯

VerilogHDL编写的交通灯

1. module trafficlight(clk,lx,lx_l,lx_r,ly,ly_l,ly_r,c,done,m);input clk,c;//始终和初始化控制output done;output [5:0]m;//倒计时寄存器output lx,lx_l,lx_r,ly,ly_l,ly_r;//指示灯(分别是X、Y方向的直行、左转和右转)reg lx,lx_l,lx_r,ly,ly_l,ly_r;reg [5:0]m;reg [1:0]state;//状态机reg done;parameters0=2'b00,s1=2'b01,s2=2'b10,s3=2'b11;//-------------------------------------------//状态模块always@(posedge clk)if(c)begin done<=1;state<=2'b00;endelsebegincase(state)s0:if(done)begin m<=6'd44;done<=0;endelse if(m>1) m<=m-1;elsebegin state<=s1;done<=1;m<=0;ends1:if(done)begin m<=6'd24;done<=0;endelse if(m>1) m<=m-1;elsebegin state<=s2;done<=1;m<=0;ends2:if(done)begin m<=6'd29;done<=0;endelse if(m>1) m<=m-1;elsebegin state<=s3;done<=1;m<=0;ends3:if(done)begin m<=6'd14;done<=0;endelse if(m>1) m<=m-1;elsebegin state<=s0;done<=1;m<=0;endendcaseend//-----------------------------------------//输出模块always@(posedge clk)begincase(state)s0:{lx,lx_l,lx_r,ly,ly_l,ly_r}<=6'b101001;s1:{lx,lx_l,lx_r,ly,ly_l,ly_r}<=6'b011001; s2:{lx,lx_l,lx_r,ly,ly_l,ly_r}<=6'b001101; s3:{lx,lx_l,lx_r,ly,ly_l,ly_r}<=6'b001011; endcaseend//-------------------------------------------- endmodule2.生成的状态机3.整体的图,四个状态都包括X方向由直行变左转,符合倒计时的要求。

4 基于Verilog_HDL设计的交通灯——代码

4 基于Verilog_HDL设计的交通灯——代码
module traffic_top(clr,clk,red_led,yellow_led,green_led,a,b,c,d,e,f,g,p,sel);
input clr,clk;
output red_led,yellow_led,green_led,a,b,c,d,e,f,g,p,sel;
endcase
else begin
if(timer>8'h46)timer<=8'h00;
else if(timer==8'h?0)timer<=timer-4'h7;
else timer<=timer-1'b1;
end
endmodule
anydiv_clk anydiv_clk1(.cki(clk),.f(2'd2),.cko(second)),
anydiv_clk2(.cki(clk),.f(12'd1000),.cko(scanclk));
deled deled(.in(din),.a(a),.b(b),.c(c),.d(d),.e(e),.f(f),.g(g),.dp(p));
assign red_led=(state==red)?1:0;
assign green_led=(state==green)?1:0;
assign yellow_led=(state==yellow)?1:0;
always@(posedge clk or negedge clr) //posedge state_clk or
if(q>8'h46)q=8'h01;
else if(q==8'h?0)q=q-4'h7;

基于VerilogHDL设计的交通灯控制系统

基于VerilogHDL设计的交通灯控制系统

基于Verilog HDL 设计的交通灯控制系统何 峰(华东师范大学软件学院 上海 200062)摘 要:Ver ilog HDL 作为一种规范的硬件描述语言,被广泛应用于电路的设计中。

他的设计描述可被不同的工具所支持,可用不同器件来实现。

利用V erilo g HDL 语言自顶向下的设计方法设计交通灯控制系统,使其实现道路交通的正常运转,突出了其作为硬件描述语言的良好的可读性、可移植性和易理解等优点,并通过Xilinx ISE6.02和M odelSim5.6完成综合、仿真。

此程序通过下载到F PG A 芯片后,可应用于实际的交通灯控制系统中。

关键词:V erilo g HDL ;硬件描述语言;状态;F PG A中图分类号:T P 312 文献标识码:B 文章编号:1004373X (2005)0810302Design of Traffic Light Controller System Based on Verilog HDLHE F eng(Scho ol of So ft ware ,East Chi na N ormal Uni v ersit y ,Shanghai ,200062,Chi na )Abstract :A s a co mmon languag e for the descript ion o f har dwar e,V er ilo g HDL is w idely applied in cir cuit desig ning.T he desig n descr iptio n can be suppor tted by different too ls a nd implemented by differ ent devices .In this paper ,t he pr o cess o f desig ning t raffic light co ntro ller system by the V erilo g HD L top do w n desig n method is pr esented ,which has made the ro ad traffic w or k well ,t he design of t his sy stem has sho wn the r eadabilit y,po rt ability and easily under st anding of V erilo g HDL as a har d descr iption lang uage.Cir cuit synthesis and simula tio n are perfo rmed by Xilinx ISE6.02and M o delSim 5.6.T he pr og ram can be used in the tr uly t raffic light contr oller system by do wnloading t o the F PG A chip .Keywords :Ver ilog HDL ;har dw ar e descript ion languag e;state;FP GA收稿日期:200411181 引 言HDL (Hardw are Description L ang uage,硬件描述语言)是一种描述硬件所做工作的语言。

Verilog语言实现设计交通灯控制器

Verilog语言实现设计交通灯控制器

Verilog语言实现设计交通灯控制器实验模块组成:(计数器+控制器)可以分开实现,最好一起实现避免接口对接时出错译码器实验要求:1.在十字路口两个方向各设一组红、绿、黄灯,显示顺序为:南北方向是绿、黄、红灯;东西方向是红、绿、黄灯。

2.要求红、绿、黄灯的持续时间分别为:10s、7s、3s,东西、南北方向各用一个数码管显示倒计时时间。

3.当任意方向出现特殊情况时,应优先放行,即使各方向均亮红灯,倒计时停止,且显示数字闪烁。

经过规定时间之后,恢复正常运行状态。

//计数器+控制器module ZTJ(clk,s,count1,count2,led);parameter s0=6’b010100,s1=6’b001100,s2=6'b100010,s3=6'b100001,s4=6'b100100;input clk,s;output[3:0]count1;output[3:0]count2;output[5:0]led;reg[3:0]count1;reg[3:0]count2;reg[5:0]led;reg[5:0]st;reg[5:0]jicun;reg[3:0]i;always @(posedge clk)if(s==0 &led==6’b000000)beginled<=s0;st<=s0;count1<=4'b0110;count2〈=4’b1001;endelse if(s==0 & led!=6’b000000)begincase(st)s0:if(count1!=4'b0000) begin led<=s0;count1〈=count1—1;count2<=count2-1;end else begin count1<=4'b0010;st<=s1;ends1:if(count1!=4'b0000)begin led〈=s1;count1〈=count1—1;count2<=count2-1;end else begin count1〈=4’b1001;count2<=4'b0110;st<=s2;ends2:if(count2!=4’b0000) begin led〈=s2;count1<=count1-1;count2〈=count2-1;end else begin count2〈=4’b0010;st〈=s3;ends3:if(count2!=4'b0000)begin led<=s3;count1〈=count1—1;count2〈=count2—1;end else begin count1<=4’b0110;count2〈=4’b1001;st<=s0;enddefault:led<=s4;endcaseendelsebeginjicun<=led;led〈=s4;count1<=count1;count2〈=count2;i<=i+1;if(i==4’b1001)led〈=jicun;endendmodule//译码器module DECL7S(A,LED7S);input [3:0]A;output [6:0]LED7S;reg [6:0]LED7S;always@(A)begincase(A)4’b0000:LED7S<=7'b0111111;4’b0001: LED7S<=7'b0000110;4'b0010: LED7S<=7'b1011011;4'b0011:LED7S〈=7'b1001111;4'b0100:LED7S<=7’b1100110;4’b0101:LED7S<=7’b1101101;4'b0110: LED7S<=7’b1111101;4'b0111:LED7S<=7'b0000111;4’b1000:LED7S<=7'b1111111;4’b1001: LED7S<=7'b1101111;4'b1010: LED7S<=7’b1110111;4’b1011:LED7S〈=7'b1111100;4’b1100: LED7S〈=7'b0111001;4'b1101:LED7S<=7’b1011110;4'b1110: LED7S<=7'b1111001;4’b1111:LED7S〈=7’b1110001;default:LED7S〈=7'b0111111;endcaseendendmodule。

基于Verilog HDL语言的带左转复杂交通灯设计

基于Verilog HDL语言的带左转复杂交通灯设计
维普资讯
Mirc mp trA piain o. 2 N . ,06 coo ue p l t sV 12 , o 4 2 0 c o
文 章 编 号 :0 7 5 X(0 6 0 -O 3 一 O 1 0 —7 7 2 0 )4 O 7 3
开 发 应 用
在语言 中。

路径和设计 的时序检查 。

可 以 用 三 种 不 同方 式 或 混 和 方 式 对 设 计 建 模 这 些 方 式
包 括 : 为 描 述 方 式 —— 使 用 过 程 化 结 构 建 模 ; 据 流 方 式 行 数
— —
使 用 连 续 赋 值 语 句 方 式 建 模 ; 构 化 方 式 —— 使 用 门和 结 能 够 描 述 层 次 设 计 , 使 用 模 块 实 例 结 构 描 述 任 何 层 可

设计 能够在 多个层 次相加 以描述 , 开关级 , 级 , 从 门 寄 能 够 监 控 拟 验 证 的执 行 , 模 拟 验 证 执 行 过 程 这 设 计 即
级 器传 送 级 ( TL 到算 法 级 , 括 进 程 和 队 列 级 。 R ) 包

成 开 发 环 境 进 行 综 合 、 真 , 下 载 到 C L 可 编 程 逻 辑 器 件 仿 并 PD
次。

用 户 定 义 原语 ( P) 建 的 灵 活 性 。用 户 定 义 的 原 语 UD 创
既 可 以是 组 合 逻 辑 原 语 , 可 以 是 时 序 逻 辑 原 语 。 也

开 关 级 基 本 结 构 模 型 , 如 p s n s 也 被 内置 例 mo 和 mo 等
提供 显示 语 言 结 构 制 定 设 计 中 的 端 口到 端 口的 时 延 及

基于verilog HDL数字系统设计--交通灯

基于verilog HDL数字系统设计--交通灯

交通灯控制器-------数字系统设计文档姓名:学号:一.课题简介:我在本课程中所选择的课题是用Verilog HDL 实现的交通灯控制器。

该交通灯控制器处在一个城乡结合处的十字路口,这个十字路口分为主干道和乡村公路,由于主干道的车流量远大于乡村公路的车流量,所以这个交通灯控制器不同于常见的交通灯控制器。

这个交通控制器的功能有如下几点:1.当乡村公路无车时,始终保持乡村公路红灯亮,主干道绿灯亮。

2.当乡村公路有车时,而主干道通车时间已经超过它的最短通车时间时,禁止主干道通行,让乡村公路通行。

主干道最短通车时间为25s 。

3.当乡村公路和主干道都有车时,按主干道通车25s,乡村公路通车16s交替进行。

4.不论主干道情况如何,乡村公路通车最长时间为16s。

5.在每次由绿灯亮变成红灯亮的转换过程中间,要亮5s时间的黄灯作为过渡。

6.用开关代替传感器作为检测车辆是否到来的信号。

用红、绿、黄三种颜色的发光二极管作交通灯。

要求显示时间,倒计时。

二.控制框图和设计流程图:1.这个交通灯控制器由三个主要部分组成---核心控制器以及、译码器、分频器。

2.流程图的内容同上面交通灯的功能,这里不再多做解释。

三.各部分组件的具体实现和分析:1.核心控制器实现基本功能:(1)它的输入端有4个输入信号—C、RST、ST、CLK。

C信号是一个检测信号,检测乡村公路是否有车,C=0示无车,这种情况下乡村公路一直亮红灯,主干道一直亮红灯,并且两个计数器都同步30秒重复计数,直到C=1即乡村公路有车是才跳变到其他情况。

RST信号是复位信号,当RST=0时,这个交通灯控制器才能正常工作。

当RST=1时,所有计数器都立刻赋初值,并且乡村公路和主干道都亮红灯,表示交通灯控制器出了故障,为防止意外发生,禁止通行。

ST信号表示使能信号,当ST=1时,交通灯控制器才能正常工作。

ST=0时,所有计数器都停止计数,并且乡村公路和主干道都亮红灯,表示交通灯控制器出了故障,为防止意外发生,禁止通行。

基于Verilog语言的交通控制灯设计

基于Verilog语言的交通控制灯设计

基于Verilog语言的交通控制灯设计作者:张哲郭昭利段品凡曾健王彦博朱志刚来源:《电脑知识与技术》2019年第10期摘要:为实现智能交通控制灯的功能,以FPGA应用设计为基础,使用Verilog HDL 语言编写并且使用Quartus Ⅱ进行仿真。

本设计包含主控模块、电源模块、时钟模块、LED显示模块,实现设计功能且验收效果良好。

关键词:FPGA;Verilog;Quartus;Ⅱgfdg中图分类号:TP311 文献标识码:A文章编号:1009-3044(2019)10-0204-02开放科学(资源服务)标识码(OSID):在当下,人们生活水平的提高,越来越多的人拥有车辆,交通事故成为社会难题,在这样的背景下,智能交通灯应运而生。

1 原理1.1 FPGA简介FPGA(Field-Programmable Gate Array),即现场可编程门阵列,它于80年代中期Xilinx 推出,是在PAL、GAL、CPLD等可编程器件的基础上进一步发展的产物。

FPGA是作为专用集成电路(ASIC)领域中的一种半定制电路而出现的,既解决了定制电路的不足,又克服了原有可编程器件门电路数有限的缺点。

FPGA以并行运算为主,以硬件描述语言来实现;相比于PC或单片机(无论是冯诺依曼结构还是哈佛结构)的顺序操作有很大区别,FPGA开发需要从顶层设计、模块分层、逻辑实现、软硬件调试等多方面着手。

1.2 Verilog 语言简介Verilog HDL是一种硬件描述语言,用于从算法级、门级到开关级的多种抽象设计层次的数字系统建模。

被建模的数字系统对象的复杂性可以介于简单的门和完整的电子数字系统之间。

数字系统能够按层次描述,并可在相同描述中显式地进行时序建模。

2 总体设计本设计总体框图如下:3 详细设计3.1 设计要求交通控制灯的东西方向用R1、Y1、G1示意,南北方向用R2、Y2、G2示意,时钟周期CLK为1秒。

本设计分为6种状态,状态0:R2、G1亮,其他灭,持续20秒;状态1:R2亮,G1闪烁,其他灭,持续5秒;状态2:R2、Y1亮,其他灭,持续5秒;状态3:G2、R1亮,其他灭,持续20秒;状态4:R1亮,G2闪烁,其他灭,持续5秒;状态5:Y2、R1亮,其他灭,持续5秒;后返回状态1。

交通信号灯控制器的verilog实现

交通信号灯控制器的verilog实现

H a r b i n I n s t i t u t e o f T e c h n o l o g yV e r i l o g实验报告(2)实验内容:交通信号灯控制器班级:姓名:学号:哈尔滨工业大学2015年6月一、功能描述本设计利用Verilog HDL 语言,对一个十字路口的交通信号灯进行控制,可控制4个路口的红、黄、绿、左转四盏信号灯,让其按特定的规律进行变化。

并通过ModelSim软件对系统进行了仿真。

仿真结果表明系统可自动实现十字路口红绿灯及左转弯信号灯的控制。

实现设计目标如下:(1)设计一个十字路口的交通灯控制电路,每条路配有红、黄、绿、左转四盏交通信号灯。

通过控制器对四个路口的四组交通灯的状态实现自动循环控制;(2)实现两主干道车辆交替运行,每次通行直行时间为30 秒;左转时间为10秒,右转不受信号灯控制。

(3)黄灯作为绿灯转为左转灯,左转灯转为红灯的过渡信号灯,过渡时间为5s。

(4)系统设有总复位开关,可在任意时间对系统进行复位。

二、设计方案1.设计思路我们对图1所示的十字路口进行设计,路口A和路口C的车辆同时行驶,路口B和路口D的车辆同时行驶,所以虽然要控制4组信号灯,但其实它们可以俩俩合并,这样大大简化了设计。

由于我们采用自动控制方式,两个方向的灯按照顺序依次交替循环显示,每种灯亮的时间结合实际生活合理设定。

系统设有复位开关,可在任意时间内对系统进行复位。

图1 十字路口示意图由以上分析可知,该系统可视为一个状态机,而且共有8种状态,如表1所示。

表1 交通灯状态示意表由上表我们还可以得到状态转换图,如图2所示:图2 状态转移示意图该状态机共有两个输入信号rstn和clk,rstn为复位信号,当该信号为低电平时,状态机处于S0,且状态不发生改变。

当rstn为高电平时,这8个状态依次按时间顺序发生变化,每个状态保持多长时间由clk信号控制。

三、关键代码1.我们通过宏定义来设置每个状态保持的时间,这样既增强了代码的可读性,又方便以后的更改。

基于Verilog HDL语言的复杂交通指标灯设计与实现

基于Verilog HDL语言的复杂交通指标灯设计与实现

基于Verilog HDL语言的复杂交通指标灯设计与实现
杨杨
【期刊名称】《电脑编程技巧与维护》
【年(卷),期】2011(000)014
【摘要】为克服采用单片机或PLC来实现交通灯控制器的不足,在已有基于Verilog HDL硬件描述语言的交通灯设计的基础上,给出了一种基于Verilog HDL 硬件描述语言的复杂交通指标灯设计;同时,选择XINLINX公司的FPGA芯片,采用ISE9.li开发工具进行了程序的编译与功能仿真,实现了交通灯控制器的硬件电路描述.仿真结果验证了提出的设计方案的正确性,下载到在线可编程逻辑器件CPLD芯片,实现了相应的功能.
【总页数】4页(P27-29,34)
【作者】杨杨
【作者单位】南京师范大学强化培养学院,南京,210046
【正文语种】中文
【相关文献】
1.基于Matlab与Verilog HDL的FIR滤波器设计与实现 [J], 陈新锐;林卿;唐晓虎;叶志祥
2.基于Verilog HDL的流水线模型机的设计与实现 [J], 易小琳;彭一凡
3.基于Verilog HDL的异步FIFO设计与实现 [J], 魏芳;刘志军;马克杰
4.基于Verilog HDL语言的带左转复杂交通灯设计 [J], 郭长辉;王思明
5.基于Verilog HDL的通用UART模块设计与实现 [J], 吕阳; 刘莉娜; 郑良广; 侯晓伟
因版权原因,仅展示原文概要,查看原文内容请购买。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

2009.2011.141引言针对采用单片机和可编程控制器PLC 实现交通灯控制器的不足,如:存在修改、调试均需要硬件电路支持,且存在采用的电路原件相对较多、接线复杂、故障率高、可靠性低等不足[1,2]。

尽管文献[3,4]的作者在实时性和自适应控制系统设计方面展开了研究,但其依赖硬件电路支持的不足仍然存在。

为此,研究者和工程师们寻求其他设计交通灯控制器的途径,而随着Electronic Design Automation 技术的发展,在线可编程逻辑器件PLD 的出现,使得用户在实验室制作专用集成电路成了现实。

研究者提出了一些基于VHDL 的交通灯控制器的设计方案[5-8],有效地克服了基于PLC 交通灯设计与实现方案的不足,其中,HDL (Hardware Description Language ,硬件描述语言)是一种描述硬件工作的语言。

Verilog HDL 是工业和学术界的硬件设计者常用的两种主要的HDL 之一。

文献[6]的作者依据Altera 公司的EDA 软件平台Max+PlusII ,给出CPLD 芯片上交通灯系统的控制过程的实现,而文献[8]的作者选择XILINX 公司的FPGA 芯片(如同文献[7]的设计工作),采用ISE5.X 和MODELSIMSE6.0开发工具进行了程序的编译和功能仿真。

2交通灯系统控制器的设计与实现2.1设计要求无论采用何种手段进行交通灯控制器的设计,交通灯控制器均遵循类似的工作机制,借用文献[5-8]的设计思路,按照以下规则对系统进行控制:(1)十字路口的A 方向(主干道)、B 方向(支干道)各设红(R),黄(Y),绿(G)和左拐(L),右拐(R )五盏灯,A 方向4种灯按“绿黄左黄红黄”的顺序循环亮灭,B 方向4种灯按“红黄绿黄左黄”的顺序循环亮灭,并能将灯亮的时间以倒计时的形式显示出来。

(2)保证主干道绝对优先,初始状态设为主干道绿灯,支干道红灯。

(3)两个方向各种灯亮的时间应该能够非常方便地进行设置和修改,此外设A 方向是主干路,车流量大,因此A 方向通行的时间在正常模式下比B 方向时间长一些。

(4)每个方向红灯亮的时间等于另一方向绿、黄、左拐、黄灯亮的时间。

而右拐灯常亮。

(5)黄灯所起的作用是用来在绿灯和左拐灯后进行缓冲,以提醒行人该方向马上要禁行了。

(6)加入智能控制功能:1)增加输入控制端Model2,用来控制当B 方向车流量过大时增加B 方向通行时间,起到分流的作用。

2)增加输入控制端warn ,形成两个模式:①单向通行模式:对于特殊时期,通过该端输入可控制两方向全为红灯。

②夜间警惕模式:在夜间A 、B 方向全为黄灯并伴随闪烁。

基于Verilog HDL 语言的复杂交通指标灯设计与实现杨杨(南京师范大学强化培养学院,南京210046)摘要:为克服采用单片机或PLC 来实现交通灯控制器的不足,在已有基于Verilog HDL 硬件描述语言的交通灯设计的基础上,给出了一种基于Verilog HDL 硬件描述语言的复杂交通指标灯设计;同时,选择XINLINX 公司的FPGA 芯片,采用ISE9.1i 开发工具进行了程序的编译与功能仿真,实现了交通灯控制器的硬件电路描述。

仿真结果验证了提出的设计方案的正确性,下载到在线可编程逻辑器件CPLD 芯片,实现了相应的功能。

关键词:Verilog HDL ;FPGA ;CPLD ;交通灯控制器Designing and Implementing a Complicated Traffic Light by UsingVerilog HDLYANG Yang(Honor School,Nanjing Normal University ,Nanjing 210046)Abstract :To overcome the disadvantages of the traffic light controller implemented by using Single Chip or PLC,based onthe existing Verilog HDL-based design strategy for traffic light,in this paper,we introduce a design strategy by using Verilog HDL,and meanwhile compile the developed grogram and simulate the function of the traffic light by employing ISE9.1i development tool for FPGA Chip made by XINLINX Company.Further,the hardware description of the traffic light controller is implemented.The simulated results show the correctness of the newly design scheme,downloading corresponding codes into the on-line CPLD chip can implement a complicated traffic light.Key words :Verilog HDL ;FPGA ;CPLD ;Traffic light controller基金项目:本课题得到南京师范大学2010年学生科学基金(首批立项)项目资助。

作者简介:杨杨,男,09级工科强化班学生。

272011.142.2系统控制器依据2.1节中介绍的交通灯控制器的功设计要求,类似于文献[6]中控制变量的设置,采用两个并行执行的always 模块来分别控制A 和B 两个方向的4盏灯,这两个always 模块使用同一个时钟信号,以进行同步,即两个always 模块的敏感信号是同一个。

同时,交通灯控制器的状态转换表如表1所示。

表1中“1”表示灯亮,“0”表示灯灭。

依据表1所示,控制程序的描述如下:module traffic (CLK,clk1,EN,LAMPA,LAMPB,seg,an1,an2,an3,an4,warn,model2);output [6:0]seg;output [4:0]LAMPA,LAMPB;output an1,an2,an3,an4;input CLK,EN,clk1,model2;input [1:0]warn;wire [7:0]ACOUNT,BCOUNT;reg an1,an2,an3,an4;//位选信号reg [6:0]seg,temp;reg [7:0]numa,numb;//存储亮灯时间的中间变量reg tempa,tempb,tempc,tempd;//A 、B 方向状态变量,控//制倒计时和各交通灯之间的转换reg [3:0]counta,countb;//亮灯顺序控制变量reg [7:0]ared,ayellow,agreen,aleft,aright,bred,byellow,bgreen,bleft,bright;reg [4:0]LAMPA,LAMPB;reg [1:0]flag=0;initial beginnuma=0;numb=0;tempa=0;tempb=0;counta=0;countb=0;ared =0;ayellow =0;agreen =0;aleft =0;bred =0;byellow =0;bgreen=0;bleft=0;LAMPA=0;LAMPB=0;endalways @(EN)if (!EN)begin //设置各种灯的计数器的预置数if (!model2)beginared <=8'b01000000;//40秒ayellow <=8'b00000101;//5秒agreen <=8'b01000101;//45秒aleft <=8'b00010101;//15秒//aright<=8'd105;bred <=8'b01100101;//65秒byellow <=8'b00000101;//5秒bleft <=8'b00010101;//15秒bgreen <=8'b00100000;//20秒//bright<=8'd105;end else beginared <=8'b01010000;//50秒ayellow <=8'b00000101;//5秒agreen <=8'b00110101;//35秒aleft <=8'b00010101;//15秒//aright<=8'd105;bred <=8'b01010101;//55秒byellow <=8'b00000101;//5秒bleft <=8'b00010101;//15秒bgreen <=8'b00110000;//30秒//bright<=8'd105;end endassign ACOUNT=numa;assign BCOUNT=numb;always @(posedge CLK)//该进程控制A 方向的四种灯if (EN)beginif (!warn)beginif (!tempa)begintempa<=1;case (counta)//控制亮灯的顺序0:begin numa<=agreen;LAMPA<=20;counta<=1;end 1:begin numa<=ayellow;LAMPA<=18;counta<=2;end 2:begin numa<=aleft;LAMPA<=24;counta<=3;end 3:begin numa<=ayellow;LAMPA<=18;counta<=4;end 4:begin numa<=ared;LAMPA<=17;counta<=5;end 5:begin numa<=ayellow;LAMPA<=18;counta<=0;end //default:LAMPA<=4;endcase end elsebegin //倒计时if (numa>1)beginif (numa [3:0]==0)beginnuma [3:0]<=4'b1001;numa [7:4]<=numa [7:4]-1;end else beginnuma [3:0]<=numa [3:0]-1;if (numa==2)tempa<=0;end end else beginA 方向B 方向10100101001001010010110001100010010100101000110001100011000110001100011111右aright 左aleft 绿agreen 黄ayellow 红ared 右aright 左aleft 绿agreen 黄ayellow 红ared 表1交通灯控制器状态转换表28LAMPA<=4'b1000;counta<=0;tempa<=0;endendendelseif(warn==1)begin LAMPA<=1;numa<=0;endelseif(warn==2)beginif(!tempc)begin LAMPA<=2;numa<=0;tempc<=1;end else LAMPA[1:1]<=~LAMPA[1:1];//黄灯闪烁endendelsebegin LAMPA<=0;counta<=0;tempa<=0;tempc<=0;end always@(posedge CLK)//该进程控制B方向的四种灯if(EN)beginif(!warn)beginif(!tempb)begintempb<=1;case(countb)//控制亮灯的顺序0:begin numb<=bred;LAMPB<=17;countb<=1;end1:begin numb<=byellow;LAMPB<=18;countb<=2;end 2:begin numb<=bgreen;LAMPB<=20;countb<=3;end3:begin numb<=byellow;LAMPB<=18;countb<=4;end 4:begin numb<=bleft;LAMPB<=24;countb<=5;end5:begin numb<=byellow;LAMPB<=18;countb<=0;end//default:LAMPB<=1;endcaseendelsebegin//倒计时if(numb>1)beginif(!numb[3:0])beginnumb[3:0]<=9;numb[7:4]<=numb[7:4]-1;endelsebeginnumb[3:0]<=numb[3:0]-1;if(numb==2)tempb<=0;endendelsebeginLAMPB<=4'b1000;tempb<=0;countb<=0;endendendelseif(warn==1)begin LAMPB<=1;numb<=0;endelseif(warn==2)beginif(!tempd)begin LAMPB<=2;numb<=0;tempd<=1;end else LAMPB[1:1]<=~LAMPB[1:1];//黄灯闪烁end endelsebegin LAMPB<=0;countb<=0;tempb<=0;tempd<=0;endalways@(posedge clk1)begin{an1,an2,an3,an4}=4'b1111;flag=flag+1;//flag不断加1case(flag)0:begin temp=numa[7:4];an1=0;end1:begin temp=numa[3:0];an2=0;end2:begin temp=numb[7:4];an3=0;end3:begin temp=numb[3:0];an4=0;endendcasecase(temp)4'd0:seg=7'b1111110;4'd1:seg=7'b0110000;4'd2:seg=7'b1101101;4'd3:seg=7'b1111001;4'd4:seg=7'b0110011;4'd5:seg=7'b1011011;4'd6:seg=7'b0011111;4'd7:seg=7'b1110000;4'd8:seg=7'b1111111;4'd9:seg=7'b1111011;//default:seg=7'b1111001;endcaseendendmodule为了更直观地加以描述,将上面的文本模块编译生成一个符号,并加上输入输出引脚,构成完整的交通灯控制器顶层电路,设计的交通灯控制器总体框图如图1所示。

相关文档
最新文档