通过Verilog实现交通灯设计实验报告名师资料合集(完整版)资料.doc
上传人:天马****23 上传时间:2024-09-10 格式:DOC 页数:28 大小:3.7MB 金币:10 举报 版权申诉
预览加载中,请您耐心等待几秒...

通过Verilog实现交通灯设计实验报告名师资料合集(完整版)资料.doc

通过Verilog实现交通灯设计实验报告名师资料合集(完整版)资料.doc

预览

免费试读已结束,剩余 18 页请下载文档后查看

10 金币

下载此文档

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

通过Verilog实现交通灯设计实验报告名师资料合集(完整版)资料(可以直接使用,可编辑优秀版资料,欢迎下载)电子科技大学实验报告一、实验室名称:虚拟仪器实验室二、实验项目名称:交通灯设计实验三、实验学时:4学时四、实验原理假设交通灯处于南北和东西两条大街的“十”字路口,如图1所示。用FPGA开发板的LED灯来模拟红、黄、绿3种颜色信号,并按一定顺序、时延来点亮LED,如图2所示。图3给出了交通灯的状态转移图。设计使用频率为1Hz的时钟来驱动电路(注1:仿真时采用1MHz的时钟来驱动电路),则停留1个时钟可得到1S的延时,类似停留3个时钟可得到3S的延时,停留15个时钟可得到15S的延时(注2:开发板工作时钟为50MHz)。图1.六个彩色LED可以表示一组交通信号灯状态机的状态南北大街东西大街开发板延时(单位:s)仿真延时(单位:us)S0红绿1515S1红黄33S2红红33S3绿红1515S4黄红33S5红红33图2.交通灯状态南北东西红黄绿红黄绿S0100001S1100010S2100100S3001100S4010100S5100100图3.交通灯的状态转移图图4.交通灯的原理框图五、实验目的本实验是有限状态机的典型综合实验,掌握如何使用状态转移图来定义Mealy状态机和Moore状态机,熟悉利用HDL代码输入方式进行电路的设计和仿真的流程,掌握Verilog语言的基本语法。并通过一个交通灯的设计掌握利用EDA软件(XilinxISE13.2)进行HDL代码输入方式的电子线路设计与仿真的详细流程。。六、实验内容在XilinxISE13.2上完成交通灯设计,输入设计文件,生成二进制码流文件下载到FPGA开发板上进行验证。七、实验器材(设备、元器件)1、计算机(安装XilinxISE13.2软件平台);2、BASYS2FPGA开发板一套(带USB-MIniUSB下载线)八、实验步骤新建工程,设置器件属性:在XilinxISE13.2平台中,新建一个工程(注意命名规范),输入工程名称以及工程所在的目录,设置芯片的具体型号(Spartan3EXC3S100E)、封装类型(CP132)以及编码使用的语言(Verilog)。(详见实验指导书)Verilog源码文件创建与编辑:选中器件名字,点击鼠标右键,选中NewSource…,选择VerilogModule以及输入文件名称(详见实验指导书)语法检查,对设计文件进行综合:代码编写完成后,在ISE的主界面的处理子窗口的synthesis的工具检查代码语法(CheckSyntax),同时在此窗口可以查看RTL原理图(ViewRTLschematic)、查看技术原理图(ViewTechnologySchematic)以及产生综合后仿真模型(GeneratePost-SynthesisSimulationModel)。对设计进行行为仿真:1)产生测试文件模板;2)完成测试脚本创建与编辑;3)调出仿真窗口对设计进行仿真;4)通过波形查看仿真结果。(详见实验指导书)添加实现约束文件。(详见实验指导书)UCF文件导入。(详见实验指导书)FPGA在线下载配置:1)连接开发板并给开发板供电;2)边界扫描,初始化链;3)下载比特流文件;4)对FPGA进行编程;5)生成PROM文件;6)将生成的PROM文件烧到PROM芯片中。(详见实验指导书)关闭配置界面,不保存任何信息。(一定不要保存任何信息)关闭电源重新上电,程序从PROM自动引导到FPGA芯片中。给开发板断电,清理器件,实验结束。九、实验数据及结果分析9.1状态机转移代码moduletraffic(inputclk,inputrst,outputreg[5:0]lights);reg[2:0]state;reg[3:0]count;parameterS0=3'b000,S1=3'b001,S2=3'b010,S3=3'b011,S4=3'b100,S5=3'b101;always@(posedgeclkorposedgerst)beginif(rst)beginstate<=S0;count<=0;endelsebegincase(state)S0:if(count<15)beginstate<=S0;count<=count+1;endelsebeginstate<=S1;count<=0;end
立即下载