




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、精选优质文档-倾情为你奉上FPGA课程设计 交通灯控制器通信工程学院电科0701班罗超(17)第一部分 技术规范 1.1功能描述:实现一个由一条主干道和一条支干道的汇合点形成的十字路口的交通灯控制器,具体功能:(1) 主、支干道各设有一个绿、黄、红指示灯,两个显示数码管。(2) 主干道处于长允许通行状态,而支干道有车来时才允许通行。当主干道允许通行亮绿灯时,支干道亮红灯。而支干道允许通行亮绿灯时,主干道亮红灯。(3) 当主干道、支干道均有车时,两者交替允许通行,主干道每次通行45 秒,支干道每次通行25 秒,在每次由绿灯向红灯转换的过程中,要亮5 秒的黄灯作为过渡,并进行减计时显示。每个周期结
2、束时都要进行支干道是否有车的检测,若有车则进行下一个周期,若没有,则主干道亮绿灯,支干道亮红灯,直到检测到支干道有车。1.2系统总体框图:根据设计要求和系统所具有的功能,并参考相关的文献资料,经行方案设计,可以画出如下图所示的交通信号灯控制器的系统框图。时钟分频模块交通灯控制模块 扫描显示译码模块clkrstcarsignal计时模块数码管段码sel数码管位码segLED灯I/O管脚的描述名称方向电平位宽功能 clkInput3.3V1系统时钟信号(10KHZ)carsignal Input3.3V1检测支路是否有车rst Input3.3V1复位信号led Output3.3V6LED灯se
3、l Output3.3V7数码管段码 seg Output3.3V4数码管位码 表一:系统总体I/O管脚的描述注:其中系统时钟的频率选为10KHZ,复位采取同步复位方式,且低有效。支干道检测到有车时, carsignal=1;否则,carsignal=0。方案核心:在交通灯控制器的设计中,交通灯控制及计时模块是本设计的关键模块。第二部分总体设计方案交通灯2.1系统详细框图:在系统总体框图的基础上进一步详细设计,得到如下系统详细框图。rstLED灯carsignalclk显示控制单元定时模块显示单元交通灯控制模块时钟分频模块译码单元数码管显示 图三:系统详细框图注:系统总体I/O管脚描述请查看技
4、术规范。2.2具体模块设计1.时钟分频模块系统的动态扫描需要10KHZ的脉冲,而系统时钟计时模块需要1HZ的脉冲。分频模块主要为系统提供所需的时钟计时脉冲。该模块将10KHZ的脉冲信号进行分频,产生1S的方波(占空比为50%),作为系统时钟计时信号。clk时钟分频模块rstclk_out 图四:时钟分频模块框图I/O管脚描述如下:名称方向电平位宽功能clkinput3.3V1系统时钟(10KHZ)rstinput3.3V1复位信号clk_outoutput3.3V1分频后时钟信号(1HZ) 表二:时钟分频模块I/O端口描述注:系统时钟的频率为10KHZ,分频后的时钟信号为1HZ(占空比为50%
5、)。复位信号为同步复位,且低有效。2.交通灯控制及计时模块控制模块JTDKZH:根据主干道、支干道输入信号以及时钟信号CLK,发出主、支干道指示灯的控制信号,同时向各个定时单元、显示控制单元发出使能控制信号产生系统的状态机,控制其他部分协调工作。计时模块分别实现45s,25s,5s的定时,根据主、支干道输入信号和时钟信号以及交通灯控制器发出的使能信号按要求进行定时用来设定主干道和支干道计时器的初值,并为扫描显示译码模块提供倒计时时间。控制模块采用状态机进行设计,可以定义出5种状态,分别为S0:主干道绿灯,支干道红灯且没有车辆行驶;S1:主干道绿灯,支干道红灯且支干道有车辆驶入;S2:主干道黄灯
6、,支干道红灯;S3:主干道红灯,支干道绿灯;S4:主干道红灯,支干道黄灯。利用CASE语句定义状态的转换方式及时间的变换方式,达到主干道绿灯亮45秒,支干道绿灯亮25秒,黄灯亮5秒的设计要求。clk_outcarsignalrstled交通灯控制模块count_H_1count_L_1count_H_2count_H_2图五:交通灯控制及计数模块I/O管脚描述如下:名称方向电平位宽功能clk_outInput3.3V1分频后时钟信号(1HZ)rstInput3.3V1复位信号(同步复位)carsignalInput3.3V1检测信号(低有效)count_H_1Output3.3V4主干道时间高
7、位译码count_L_1Output3.3V4主干道时间低位译码count_H_2Output3.3V4支干道时间高位译码count_L_2Output3.3V4支干道时间低位译码ledOutput3.3V6LED灯 表三:交通灯控制模块I/O端口描述 系统的状态图如下所示carsignal =0 S0 S3carsignal =1 S1 S2 S0:主干道绿灯,支干道红灯S1:主干道黄灯,支干道红灯S2:主干道红灯,支干道绿灯S3:主干道红灯,支干道黄灯3.扫描显示译码模块扫描显示译码模块可以根据控制信号,驱动交通信号灯以及倒计时数码管的显示,其中数码管的显示采用动态扫描显示。rstclks
8、egsel扫描显示译码模块count_H_1count_L_1count_H_2count_H_2 图六:扫描显示译码模块框图该模块的I/O管脚描述如下:名称方向电平位宽功能clkInput3.3V1系统时钟信号(10KHZ)rstInput3.3V1复位信号(低有效)count_H_1Input3.3V4主干道时间高位译码count_L_1Input3.3V4主干道时间低位译码count_H_2Input3.3V4支干道时间高位译码count_L_2Input3.3V4支干道时间低位译码selOutput3.3V7数码管段码segOutput3.3V3数码管位码表四:扫描显示译码模块I/O端
9、口描述第三部分仿真结果 Modelsim 前仿真 Quartus2后仿真第四部分 源代码分频模块:专心-专注-专业module fenpinqi(clk,rst,clk_odd);input clk,rst;output clk_odd;reg clk_odd;reg13:0 count;parameter N = 10;always (posedge clk)if(! rst)begin count <= 1'b0;clk_odd <= 1'b0;endelse if ( count < N/2-1)begin count <= count + 1
10、39;b1; endelsebegin count <= 1'b0;clk_odd <= clk_odd; endendmodule控制及计时模块:modulecontrol(led,car,rst,clk,count_H_1,count_L_1,count_H_2,count_L_2);output3:0count_H_1,count_L_1,count_H_2,count_L_2;output 5:0led;input clk,rst,car;reg 5:0 led;reg3:0count_H_1,count_L_1,count_H_2,count_L_2;reg 1:
11、0state;parameter S0=2'b00, S1=2'b01, S2=2'b10, S3=2'b11; always(posedge clk or negedge rst)if(!rst)beginled=6'b;state=S0;count_H_1=4'b0000;count_L_1=4'b0000; count_H_2=4'b0000;count_L_2=4'b0000; end else begincase(state)S0:beginBeginif(!car)begin led=6'b; /cou
12、nt_H_1=4'b0100;count_L_1=4'b0101;/? count_H_1=4'b0111;count_L_1=4'b0111; end else begin if(count_H_1 = 4'b0111) begin count_H_1=4'b0100;count_L_1=4'b0101; count_H_2=4'b0101;count_L_2=4'b0000; end else if(count_L_1=0) if(count_H_1=0) begin led=6'b; count_H_1=4&
13、#39;b0000;count_L_1=4'b0100; state<=S1; if(count_L_2=0) begin count_H_2<=count_H_2-1'b1; count_L_2<=4'b1001; end elsebegin count_L_2<=count_L_2-1'b1;end end else begin count_H_1<=count_H_1-1'b1; count_L_1<=4'b1001; if(count_L_2=0) begin count_H_2<=count_H
14、_2-1'b1; count_L_2<=4'b1001; end elsebegin count_L_2<=count_L_2-1'b1; end end elsebegin count_L_1<=count_L_1-1'b1; if(count_L_2=0) begin count_H_2<=count_H_2-1'b1; count_L_2<=4'b1001; end elsebegin count_L_2<=count_L_2-1'b1; end end end end /* begin if(!
15、car) begin count_H_2=4'b0101;count_L_2=4'b0000; end elseif(count_L_2=0) begin count_H_2<=count_H_2-1'b1; count_L_2<=4'b1001;end elsebegin count_L_2<=count_L_2-1'b1; end end */end /* if(count_L_1=0) begin if(count_H_1=0) begin led=6'b; count_H_1=4'b0000;count_L_1=
16、4'b0100; state<=S1; endelse begin count_H_1<=count_H_1-1'b1;count_L_1<=4'b1001; endend elsebegin count_L_1<=count_L_1-1'b1;end if(!car) begin count_H_2=4'b0101;count_L_2=4'b0000; end else if(count_L_2=0) begin count_H_2<=count_H_2-1'b1; count_L_2<=4'
17、b1001; end else begin count_L_2<=count_L_2-1'b1; end S1: beginif(count_L_1=0)begin if(count_H_1=0) begin led=6'b; count_H_1=4'b0010;count_L_1=4'b1001; count_H_2=4'b0010;count_L_2=4'b0100; state<=S2; endelsebegin count_H_1<=count_H_1-1'b1; count_H_2<=count_H_2-
18、1'b1; endendelsebegin count_L_1<=count_L_1-1'b1; count_L_2<=count_L_2-1'b1; end end S2:begin if(count_L_2=0) begin if(count_H_2=0) begin led=6'b; count_H_2=4'b0000;count_L_2=4'b0100; state<=S3; elsebegin count_H_2<=count_H_2-1'b1; count_L_2=4'b1001; end en
19、d else begincount_L_2<=count_L_2-1'b1;end if(count_L_1=0) begin begin count_H_1<=count_H_1-1'b1; count_L_1=4'b1001; end endelse begin count_L_1<=count_L_1-1'b1; end end S3:begin if(count_L_2=0) begin if(count_H_2=0) begin led=6'b; count_H_1=4'b0100;count_L_1=4'b1
20、001; count_H_2=4'b0100;count_L_2=4'b0100; state<=S0; end elsebegin count_H_1<=count_H_1-1'b1; count_H_2<=count_H_2-1'b1; end end else begin count_L_1<=count_L_1-1'b1; count_L_2<=count_L_2-1'b1; end endcaseend endmodule扫描译码显示模块:modulesaomiao(rst,clk,count_H_1,co
21、unt_L_1,count_H_2,count_L_2,sel,seg);input rst,clk;input3:0count_H_1,count_L_1,count_H_2,count_L_2;output 6:0sel;output 3:0seg;reg 6:0sel;reg 3:0seg;reg 15:0 count;reg 1:0 cnt; reg 3:0 data; reg clk_odd;always(posedge clk or negedge rst) begin if(!rst)begincount<=0; clk_odd<=0;end else if(coun
22、t=16'd2) begin clk_odd<=clk_odd; count<=0; end else count<=count+1'b1; end always (negedge rst or posedge clk_odd)/?1msif (!rst)begincnt<=2'b00;endelse cnt<=cnt+1'b1; always(negedge rst or posedge clk) if(!rst) begin/ sel = 7'b ;seg = 4'b1111 ;endelse begincase
23、 (cnt)2'b00: beginseg =4'b1110 ; data=count_H_1;end 2'b01: begiseg= 4'b1101 ;/ ?data=count_L_1; end 2'b10:begin / ? seg= 4'b1011 ; data=count_H_2; end 2'b11: begin/ ? seg= 4'b0111 ; data=count_L_2;end default : begin / sel = 8'b ;seg = 4'b0000 ;endendcaseendal
24、ways (data or seg)begincase(data)4'b0000:sel=7'b;4'b0001:sel=7'b;4'b0010:sel=7'b;4'b0011:sel=7'b;4'b0100:sel=7'b;4'b0101:sel=7'b;4'b0110:sel=7'b;4'b0111:sel=7'b;4'b1000:sel=7'b;4'b1001:sel=7'b;default:sel=7'b; endcas
25、eend endmodule顶层模块: module jiaotongdeng(clk,rst,car,led,sel,seg,count_H_1,count_L_1,count_H_2,count_L_2,clk_odd);input clk,rst,car;output 3:0 seg;output 6:0 sel;output 5:0 led;output 3:0count_H_1,count_L_1,count_H_2,count_L_2;output clk_odd;wire 3:0count_H_1,count_L_1,count_H_2,count_L_2;wire clk_odd;saomiao ee(rst,clk_odd,count_H_1,count_L_1,count_H_2,count_L_2,sel,seg);control rr(led,car,rst,clk_odd,count_H_1,coun
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025至2030年中国翡翠摆件数据监测研究报告
- 2025至2030年中国模切制版设备数据监测研究报告
- 关于教师职业倦怠的心得体会
- 管道工程项目管理中的难点及应对措施
- 铝材环保阳极氧化与染色技术流程
- 医院环境保洁安全保障措施
- 医疗废物管理与公共卫生职责
- 四年级上册美术家庭作业计划
- 公务员职业测试题及答案
- 超声面试考试试题及答案
- 江苏省苏州市2024-2025学年统编版(2024)第二学期七年级语文期中模拟卷(二)(含答案)
- 探讨“职继融通”研究的内涵、框架及其未来发展趋势
- 医保飞行检查培训
- 2025年中考英语押题预测卷(苏州专用)(原卷版)
- CT引导下经皮胃造瘘术专家共识(2025版)解读课件
- 2024年美容师考试相关法律法规解读试题及答案
- 2025年新版劳动合同范本
- 高压预试施工方案
- 事故隐患内部报告奖励制度
- 2025年河南焦作市孟州市开创人才服务有限公司招聘笔试参考题库附带答案详解
- 2024年高考真题-地理(河北卷) 含答案
评论
0/150
提交评论