- 1、本文档共10页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
交通灯控制电路设计
实验六 交通灯控制电路设计 1、目的要求 学习小型数字系统的设计方法;掌握VHDL语言的层次化设计方法。 2、方法原理 能显示十字路口东西、南北两个方向的红、黄、绿灯的指示状态;用两组红、黄、绿三色灯作为两个方向的红、黄、绿灯。能实现正常的倒计时功能以及用两组数码管作为东西和南北方向的倒计时显示。 3、主要实验仪器及材料 实验箱(配备Altera公司的EPM240T100C5下载板)。 4、掌握要点 用VHDL语言设计符合上述功能要求的交通灯控制器,熟练掌握层次化设计方法。 5、实验内容 (1) 画出顶层原理图; (2) 写出各功能模块的VHDL语言源程序; (3) 仿真设计内容,对照各个灯的时序分析电路工作原理; (4) 下载到实验箱,验证设计结果;完成设计报告。 LIBRARY ieee; use IEEE.STD_LOGIC_1164.ALL; use IEEE.STD_LOGIC_ARITH.ALL; use IEEE.STD_LOGIC_UNSIGNED.ALL; --******************实体定义*********************** ENTITY jtd IS PORT(clk : in STD_LOGIC;--时钟输入 rst : in STD_LOGIC;--复位键 row : out STD_LOGIC_VECTOR(3 downto 0);--输出组控制 r,y,g,bell : out STD_LOGIC ); END jtd; ARCHITECTURE led OF jtd IS --纵向路口控制灯为row1和row3;横向路口控制灯为row2和row4 constant yellow_time: integer:=2;--路口的黄灯维持秒数 constant green_time: integer:=10;--路口的绿灯和红灯维持秒数 signal p : integer range 0 to 3;--扫描计数器 signal f : integer range 0 to 3;--状态控制寄存器 signal clk_500 : std_logic;--扫描时钟 signal clk_1h : std_logic;--1s时钟 signal r0,y0,g0 : std_logic;--纵向路口控制信号 signal r1,y1,g1 : std_logic;--横向路口控制信号 BEGIN bell=0; --*************500Hz分频程序******************** process(clk) variable cnt1 : integer range 0 to 200; variable cnt2 : integer range 0 to 250; begin if clkevent and clk=1 then if cnt1=200 then cnt1:=0; if cnt2=250 then cnt2:=0; clk_500=not clk_500; else cnt2:=cnt2+1; end if; else cnt1:=cnt1+1; end if; end if; end process; --***********1Hz分频程序和扫描信号产生******************** process(clk_500) variable cnt1 : integer range 0 to 250; begin if clk_500event and clk_500=1 then if(p=3)then p=0; else p=p+1; end if; if cnt1=250 then cnt1:=0; clk_1h=not clk_1h; else cnt1:=cnt1+1; end if; end if; end process; 引脚分配 Assignments菜单下的pins 在下方会列出本项目所以的输入输出引脚名。 分配完引脚必须再次编译才能存储这些引脚锁定信息。 配置下载电缆 1.TOOLS----?PROGRAMMER 2. * 双击LOCATION *
文档评论(0)