1八位序列检测器设计班级:1302012学号:13020120055姓名:郭春晖2一、设计说明使用quartus软件进行仿真和验证,并且还可以检测其他的序列,只需要修改一部分代码就可以实现。二、方案工作原理:基于FPGA的多路脉冲序列检测器的设计方案,使用VHDL语言设计时序逻辑电路,先设计序列发生器产生序列:1011010001101010;再设计序列检测器,检测序列发生器产生序列,若检测到信号与预置待测信号相同,则输出“1”,否则输出“0”,并且将检测到的信号的显示出来。三、单元模块设计1、序列信号发生器序列信号是指在同步脉冲作用下循环地产生一串周期性的二进制信号。利用状态机设计,首先定义一个数据类型FSM_ST它的取值为st0到st15的16个状态。REGs0s1s2s3s4s5s6s7Q10110100REGs8s9s10s11s12s13s14s15Q01101010序列信号发生器的代码如下:LIBRARYIEEE;USEIEEE.STD_LOGIC_1164.ALL;ENTITYSHKISPORT(CLK,RST:INSTD_LOGIC;CO:OUTSTD_LOGIC);ENDSHK;ARCHITECTUREbehavOFSHKISTYPEFSM_STIS(s0,s1,s2,s3,s4,s5,s6,s7,s8,s9,s10,s11,s12,s13,s14,s15);SIGNALREG:FSM_ST;SIGNALQ:STD_LOGIC;BEGINPROCESS(CLK,RST)3BEGINIFRST='1'THENREG=s0;Q='0';ELSIFCLK'EVENTANDCLK='1'THENCASEREGISWHENs0=Q='1';REG=s1;WHENs1=Q='0';REG=s2;WHENs2=Q='1';REG=s3;WHENs3=Q='1';REG=s4;WHENs4=Q='0';REG=s5;WHENs5=Q='1';REG=s6;WHENs6=Q='0';REG=s7;WHENs7=Q='0';REG=s8;WHENs8=Q='0';REG=s9;WHENs9=Q='1';REG=s10;WHENs10=Q='1';REG=s11;WHENs11=Q='0';REG=s12;WHENs12=Q='1';REG=s13;WHENs13=Q='0';REG=s14;WHENs14=Q='1';REG=s15;WHENs15=Q='0';REG=s0;WHENOTHERS=REG=s0;Q='0';ENDCASE;ENDIF;ENDPROCESS;CO=Q;ENDbehav;转化成可调用的元件:波形仿真如下:42、序列检测器脉冲序列检测起可用于检测一组或多组二进制码组成的脉冲序列信号,当序列检测器连续接收到一组穿行二进制码后,如果这组码与检测器中预先设置的码相同,则输出1,否则输出0。由于这种检测的关键在于正确码的收到必须是连续的,这就要求检测器必须记住前一次的正确码及正确的序列,直到连续的检测中所收到的每一位码都与预置数的对应码相同。在检测过程中,任何一位不相等将回到初始状态重新开始检测。序列检测器的代码如下:libraryieee;useieee.std_logic_1164.all;entitySCHK1isport(datain,clk:instd_logic;t:instd_logic_vector(4downto0);q:outstd_logic;cq:outstd_logic_vector(4downto0));endSCHK1;architecturert1ofSCHK1issignalreg:std_logic_vector(4downto0);beginprocess(clk)variablet1:std_logic_vector(4downto0);beginifclk'eventandclk='1'thenreg(0)=datain;reg(4downto1)=reg(3downto0);endif;t1:=t;ifreg=t1thenq='1';elseq='0';cq=reg;5endif;endprocess;endrt1;可调用的元件:图3.3波形仿真如下:3、计数器利用序列检测器产生的信号(1和0)作为计数器模块的时钟信号,产生的信号0、1变化,形成类似的CLK信号,实现计数器计数。计数器的代码如下:LIBRARYIEEE;USEIEEE.STD_LOGIC_1164.ALL;USEIEEE.STD_LOGIC_UNSIGNED.ALL;ENTITYCOUNTISPORT(CLK,EN,RST:INSTD_LOGIC;Q1:OUTSTD_LOGIC_VECTOR(3DOWNTO0);Q2:OUTSTD_LOGIC_VECTOR(3DOWNTO0);COUT:OUTSTD_LOGIC);ENDENTITYCOUNT;ARCHITECTUREONEOFCOUNTISBEGIN6PROCESS(CLK,EN,RST)VARIABLECQI:STD_LOGIC_VECTOR(7DOWNTO0);BEGINIFRST='1'THENCQI:=(OTHERS='0');ELSIFCLK'EVENTANDCLK='1'THENIFEN='1'THENIFCQI153THENIFCQI(3DOWNTO0)=9THENCQI:=CQI+7;--高位进位ELSECQI:=CQI+1;ENDIF;ELSECQI:=(OTHERS='0');ENDIF;ENDIF;ENDIF;IFCQI=153THENCOUT='1';ELSECOUT='0';ENDIF;Q1=CQI(3DOWNTO0);Q2=CQI(7DOWNTO4);ENDPROCESSCOUNT;ENDARCHITECTUREONE;可调用的元件:波形仿真如下:74、顶层文件设计通过前面的准备,我们得到了3个模块,即序列信号发生器、序列检测器、计数器。在此,我们运用原理图法来生成顶层实体。即将上述3个模块,通过我们的设计软件,生成可以移植,调用的原理图文件,在将其在顶层设计中直接调用即可。本次设计生成的顶层实体如下图所示:8四波形仿真与验证1、时序仿真置入待检测序列:仿真结果:2、管脚连接NodeNameLocation1count[3]PIN_J22count[2]PIN_J33count[1]PIN_H14count[0]PIN_F25date[7]PIN_J66date[6]PIN_H57date[5]PIN_H68date[4]PIN_G49date[3]PIN_G510date[2]PIN_J711date[1]PIN_H712date[0]PIN_E313errorPIN_J13、结果分析:输入待测序列若有检测的序列则会加一,之后继续检测。