大型完整系统设计实例-交通灯和频率计_第1页
大型完整系统设计实例-交通灯和频率计_第2页
大型完整系统设计实例-交通灯和频率计_第3页
大型完整系统设计实例-交通灯和频率计_第4页
大型完整系统设计实例-交通灯和频率计_第5页
已阅读5页,还剩30页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、第6章大型完整系统设计实例1精选PPT第一部分交通灯信号控制器的设计2精选PPT设计一个主干道和支干道十字路口的交通管理系统,并用VHDL进行描述。该交通管理系统的技术要求为:如果只有一个方向有车时,则保持该方向畅通;当两个方向都有车时, 主干道和支干道交替通行, 但主干道通行的时间要比支干道长一些。 3精选PPT系统设计第一步:在明确技术要求的基础上,首先制定系统的设计方案。 第二步: 系统划分,得到系统结构图。第三步:根据设计方案和系统结构图进行算法设计, 可以画出控制系统的ASM图。第四步:设计输入,用VHDL对该系统进行描述。4精选PPT根据技术要求,在主干道和支干道两个方向上都安装红

2、、黄、绿三色信号灯;Ca和Cb分别是安装在主干道和支干道上的传感器,用于检测是否有车辆需要通过路口。在只有主干道有车时, 主干道亮绿灯, 支干道亮红灯;当只有支干道有车时,主干道亮红灯,支干道亮绿灯;当两个方向都有车时,则两个方向轮流亮绿灯和红灯,但主干道每次亮绿灯的时间不得少于60s,支干道每次亮绿灯的时间不得多于40s,在由绿灯转红灯之间要有10s的黄灯(公共停车时间)作为过渡。本系统最终采用可编程逻辑器件来实现。第一步:在明确技术要求的基础上,首先制定系统的设计方案。5精选PPT交通管理系统的结构图 第二步: 系统划分,得到系统结构图。 根据以上的设计方案, 可以画出系统的结构图。 6精

3、选PPT 本系统主要由控制器和受控制的定时器组成。定时器用来确定主干道、支干道通行时间以及公共停车时间;CNT是定时的值; LD是定时值的同步预置信号,高电平有效;ST是这个定时器的状态信号,当定时结束时,ST输出为1; Ca和Cb分别为主干道和支干道的传感器输出信号,高电平表示有车需要通过;clk是周期为秒的时钟信号;reset是异步复位信号,低电平有效,复位后的初始状态为主干道畅通;Ra、Ya、Ga和Rb、Yb、Gb分别为主干道和支干道的红、黄、绿灯的控制信号,高电平有效。 7精选PPT 第三步:根据设计方案和系统结构图进行算法设计, 可以画出控制系统的ASM图。 ASM图很清楚地表明了该

4、交通管理系统共有4个状态(S0、 S1、 S2和S3)以及各状态之间的转换关系。8精选PPT当ST=1时, LD =1,CNT的值取决于当前的状态和Ca、Cb的值。CNT的取值表状态Ca、CbCNTS0Cb=060Cb=110S140S2Ca=040Ca=110S360 第四步:设计输入,用VHDL对该系统进行描述。 本设计采用分层次描述,以下为VHDL源文件。9精选PPT-定时器模块(count.vhd): LIBRARY IEEE; USE IEEE.STD-LOGIC-1164.ALL; USE IEEE.STD-LOGIC-UNSIGNED.ALL; ENTITY counter IS

5、 PORT( reset ,clk ,LD : IN STD-LOGIC; CNT : IN INTEGER RANGE 0 TO 63; ST : OUT STD-LOGIC ); END ENTITY counter; ARCHITECTURE arch OF counter IS SIGNAL Q : INTEGER RANGE 0 TO 63; BEGIN PROCESS( reset, clk )- -定时器进程 BEGIN 10精选PPTIF( reset = 0 ) THEN Q = 60; ELSIF( clkEVENT AND clk = 1 ) THEN IF( LD =

6、1 ) THEN Q = CNT; ELSIF ( Q /= 0 ) THEN Q = Q1; END IF; END IF;END PROCESS; PROCESS( reset ,clk ) -定时器ST的进程 BEGIN IF( reset = 0 ) THEN ST = 0; ELSIF( clkEVENT AND clk = 1 ) THEN IF( Q = 2 )THEN ST = 1; ELSE ST = 0; END IF; END IF; END PROCESS; END ARCHITECTURE arch;11精选PPT -控制器模块(control.vhd): LIBRA

7、RY IEEE; USE IEEE.STD-LOGIC-1164.ALL; USE IEEE.STD-LOGIC-UNSIGNED.ALL; ENTITY con-trol IS PORT( reset ,clk ,ST ,Ca ,Cb : IN STD-LOGIC; Ra ,Ya ,Ga ,Rb ,Yb ,Gb ,LD : OUT STD-LOGIC; CNT : OUT INTEGER RANGE 0 TO 63 ); END ENTITY con-trol; ARCHITECTURE arch OF con-trol IS CONSTANT T1 : INTEGER : = 60; CO

8、NSTANT T2 : INTEGER : = 40; CONSTANT T3 : INTEGER : = 10; TYPE STATE-TYPE IS ( S0 ,S1 ,S2 ,S3 ); SIGNAL state : STATE-TYPE; SIGNAL RYG : STD-LOGIC-VECTOR( 5 DOWNTO 0 ); BEGIN 12精选PPT PROCESS( reset ,clk ) -描述状态转换 BEGIN IF( reset = 0 ) THEN state IF( Cb = 0) THEN state = S0; ELSE state state IF(Ca =

9、0) THEN state = S2; ELSE state state = S0; END CASE; END IF; END IF; END PROCESS; 13精选PPT-描述交通灯控制信号 Ra = RYG(5); Ya = RYG(4); Ga = RYG(3); Rb = RYG(2); Yb = RYG(1); Gb RYG RYG RYG RYG = 100010; END CASE; END PROCESS; LD IF( Cb = 0) THEN CNT = T1;ELSE CNT CNT IF( Ca = 0) THEN CNT = T2;ELSE CNT CNT =

10、T1; END CASE; END PROCESS; END ARCHITECTURE arch; 14精选PPT-顶层文件(traffic.vhd): LIBRARY IEEE; USE IEEE.STD-LOGIC-1164.ALL; USE IEEE.STD-LOGIC-UNSIGNED.ALL; PACKAGE traffic-lib IS COMPONENT con-trol IS PORT( reset ,clk ,ST ,Ca ,Cb : IN STD-LOGIC; Ra ,Ya ,Ga ,Rb ,Yb ,Gb ,LD : OUT STD-LOGIC; CNT : OUT INT

11、EGER RANGE 0 TO 63 ); END COMPONENT con-trol; 15精选PPT COMPONENT counter IS PORT( reset ,clk ,LD : IN STD-LOGIC; CNT : IN INTEGER RANGE 0 TO 63; ST : OUT STD-LOGIC ); END COMPONENT counter; END PACKAGE traffic-lib; LIBRARY IEEE; USE IEEE.STD-LOGIC-1164.ALL; USE IEEE.STD-LOGIC-UNSIGNED.ALL; USE WORK.t

12、raffic-lib.ALL; ENTITY traffic IS PORT( reset ,clk ,Ca ,Cb : IN STD-LOGIC; Ra ,Ya ,Ga ,Rb ,Yb ,Gb : OUT STD-LOGIC ); END ENTITY traffic;16精选PPTARCHITECTURE arch OF traffic IS SIGNAL ST ,LD : STD-LOGIC; SIGNAL CNT : INTEGER RANGE 0 TO 63; BEGIN u1:con-trol PORT MAP( reset ,clk ,ST ,Ca ,Cb ,Ra ,Ya ,Ga

13、 ,Rb ,Yb ,Gb ,LD ,CNT ); u2:counter PORT MAP( reset ,clk ,LD ,CNT ,ST ); END ARCHITECTURE arch;17精选PPT第二部分数字频率计的设计18精选PPT 1. 设计思路 下图是8位十进制数字频率计的电路逻辑图,它由一个测频控制信号发生器TESTCTL、8个有时钟使能的十进制计数器CNT10、一个32位锁存器REG32B组成。以下分别叙述频率计各逻辑模块的功能与设计方法。 19精选PPT8位十进制数字频率计逻辑图20精选PPT 1) 测频控制信号发生器设计 频率测量的基本原理是计算每秒钟内待测信号的脉冲个数

14、。这就要求TESTCTL的计数使能信号TSTEN能产生一个1秒脉宽的周期信号,并对频率计的每一计数器CNT10的ENA使能端进行同步控制。当TSTEN高电平时,允许计数;低电平时,停止计数,并保持其所计的数。在停止计数期间,首先需要一个锁存信号LOAD的上跳沿将计数器在前1秒钟的计数值锁存进32位锁存器REG32B中,并由外部的7段译码器译出并稳定显示。锁存信号之后,必须有一清零信号CLR_CNT对计数器进行清零,为下1秒钟的计数操作作准备。测频控制信号发生器的工作时序如图所示。为了产生这个时序图,需首先建立一个由D触发器构成的二分频器,在每次时钟CLK上沿到来时其值翻转。21精选PPT 其中

15、控制信号时钟CLK的频率取1 Hz,而信号TSTEN的脉宽恰好为1 s,可以用作闸门信号。此时,根据测频的时序要求,可得出信号LOAD和CLR_CNT的逻辑描述。由图可见,在计数完成后,即计数使能信号TSTEN在1 s的高电平后,利用其反相值的上跳沿产生一个锁存信号LOAD,0.5 s后,CLR_CNT产生一个清零信号上跳沿。 高质量的测频控制信号发生器的设计十分重要,设计中要对其进行仔细的实时仿真(TIMING SIMULATION),防止可能产生的毛刺。22精选PPT测频控制信号发生器工作时序23精选PPT 2) 寄存器REG32B设计 设置锁存器的好处是,显示的数据稳定,不会由于周期性的

16、清零信号而不断闪烁。若已有32位BCD码存在于此模块的输入口,在信号LOAD的上升沿后即被锁存到寄存器REG32B的内部,并由REG32B的输出端输出,然后由实验板上的7段译码器译成能在数码管上显示输出的相对应的数值。24精选PPT 3) 十进制计数器CNT10的设计 如图所示,此十进制计数器的特殊之处是,有一时钟使能输入端ENA,用于锁定计数值。当高电平时计数允许,低电平时禁止计数。25精选PPT2. VHDL源程序1) 有时钟使能的十进制计数器的源程序CNT10.VHDLIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL; -有时钟使能的十进制计数器ENTITY

17、 CNT10 ISPORT (CLK:IN STD_LOGIC; -计数时钟信号 CLR:IN STD_LOGIC; -清零信号 END:IN STD_LOGIC; -计数使能信号 CQ:OUT INTEGER RANGE 0 TO 15;-4位计数结果输出 CARRY_OUT:OUT STD_LOGIC); -计数进位 END CNT10;ARCHITECTURE ART OF CNT10 IS 26精选PPTSIGNAL CQI :INTEGER RANGE 0 TO 15;BEGIN PROCESS(CLK,CLR,ENA) BEGIN IF CLR= 1 THEN CQI= 0; -计

18、数器异步清零 ELSIF CLKEVENT AND CLK= 1 THEN IF ENA= 1 THEN IF CQI9 THEN CQI=CQI+1; ELSE CQI=0;END IF; -等于9,则计数器清零 END IF; END IF; END PROCESS; PROCESS (CQI) BEGIN IF CQI=9 THEN CARRY_OUT= 1; -进位输出 ELSE CARRY_OUT= 0;END IF; END PROCESS; CQ=CQI;END ART;27精选PPT2) 32位锁存器的源程序REG32B.VHDLIBRARY IEEE; -32位锁存器USE

19、IEEE.STD_LOGIC_1164.ALL;ENTITY REG32B IS PORT(LOAD:IN STD_LOGIC; DIN:IN STD_LOGIC_VECTOR(31 DOWNTO 0); DOUT:OUT STD_LOGEC_VECTOR(31 DOWNTO 0);END REG32B;ARCHITECTURE ART OF REG32B IS BEGINPROCESS ( LOAD, DIN )BEGINIF LOAD EVENT AND LOAD= 1 THEN DOUT=DIN; -锁存输入数据 END IF ; END PROCESS;END ART;28精选PPT3

20、) 测频控制信号发生器的源程序TESTCTL.VHD LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL; -测频控制信号发生器USE IEEE.STD_LOGIC_UNSIGNED.ALLENTITY TESTCTL IS PORT (CLK:IN STD_LOGIC; -1 Hz测频控制时钟 TSTEN:OUT STD_LOGIC; -计数器时钟使能 CLR_CNT:OUT STD_LOGIC; -计数器清零 LOAD:OUT STD_LOGIC); -输出锁存信号END TESTCTL;ARCHITECTURE ART OF TESTCTL IS SIGNA

21、L Dvi2CLK :STD_LOGIC; BEGIN29精选PPTPROCESS ( CLK )BEGINIF CLKEVENT AND CLK= 1 THEN -1 Hz时钟二分频Div2CLK=NOT Div2CLK;END IF ;END PROCESS;PROCESS ( CLK,Div2CLK )BEGIN IF CLK= 0 AND Div2CLK = 0 THEN -产生计数器清零信号 CLR_CNT= 1; ELSE CLR_CNT= 0 ; END IF; END PROCESS; LOAD=NOT Div2CLK; TSTENCLK,TSTEN=TSTEN, CLR_CN

22、T=CLR_CNT,LOAD=LOAD);U1:CNT10 PORT MAP(CLK=FSIN,CLR=CLR_CNT,ENA=TSTEN, CQ=DIN (3 DOWNTO 0),CARRY_OUT=CARRY1);U2:CNT10 PORT MAP(CLK=CARRY1,CLR=CLR_CNT,ENA=TSTEN, CQ=DIN (7 DOWNTO 4),CARRY_OUT=CARRY2);U3:CNT10 PORT MAP(CLK=CARRY2,CLR=CLR_CNT,ENA=TSTEN, CQ=DIN (11 DOWNTO 8),CARRY_OUT=CARRY3);U4:CNT10 PO

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

最新文档

评论

0/150

提交评论