您好,欢迎访问三七文档
当前位置:首页 > 临时分类 > 数字频率计FPGA设计
数字频率计设计(不羁的风作品)摘要:VerilogHDL作为一种规范的硬件描述语言,被广泛应用于电路的设计中。他的设计描述可被不同的工具所支持,可用不同器件来实现。利用VerilogHDL语言自顶向下的设计方法设计交通灯控制系统,使其实现道路交通的正常运转,突出了其作为硬件描述语言的良好的可读性、可移植性和易理解等优点。关键字:数字频率计;FPGA;VerilogHDL;硬件描述语言第一章系统总体设计考虑到测量方便,将数字频率计划分为四档:10~99Hz、100~999Hz、1000~9999Hz、10000~99999Hz。三个输入信号:待测信号、标准时钟脉冲信号和复位脉冲信号。设计细化要求:频率计能根据输入待测信号频率自动选择量程,并在超过最大量程时显示过量程,当复位脉冲到来时,系统复位,重新开始计数显示频率。基于上述要求,可以将系统基本划分为四个模块,分别为分频、计数、锁存和控制,并可以确定基本的连接和反馈,如图1所示。计数器锁存器分频器控制器输出待测信号1024Hz标准时钟系统框图RESET小数点图1系统模块组成第二章系统及模块设计说明如图2已知给定标准时钟脉冲高电平时间0T,将此高电平信号作为计数器闸门电平,通过计数器得到0T时间内待测脉冲的个数N,则有0TNf。经计算,四档的闸门电平时间0T分别为10s、1s、0.1s和0.01s。仅对计数器计数值N进行简单的移位即可得到结果。产生闸门电平的工作由分频器完成。图2测量频率原理分频器采用计数分频的方法,产生计数闸门电平和一系列控制脉冲,并接受计数器和控制器的反馈。控制器主要用来判断计数器计数是否有效,从而控制档位转换,锁存器打开、关闭和设定值。计数器在分频器和控制器的作用下对输入待测信号计数,并把计数值输出,在计数溢出时向控制器和分频器发送溢出脉冲。锁存器用来储存有效计数值,以稳定输出。第三章系统及模块具体实现与说明在分模块介绍之前先说明两个重要的寄存器状态STAT[1:0]和LATCH_STAT[1:0]。STAT[1:0]用来保存当前档位信息,STAT[1:0]等于0则为第一档,等于1则为第二档,依此类推,共可标记四档,它位于控制模块中,也是输出,这样其他模块可以通过访问它得到当前档位信息,而控制模块可以修改它从而调整档位LATCH_STAT[1:0]用来保存锁存器状态信息,LATCH_STAT[1:0]=0时,锁存器在CLK作用下打12N0开关闭。LATCH_STAT[1:0]=1时,锁存器强制置零,CLK无效。LATCH_STAT[1:0]=2时,锁存器强制置1FFFF,CLK无效。它也在控制器中,这样可以通过对其改变数值达到控制锁存器锁存、复位和显示过量程的功能。3.1计数器COUNTER计数器由四个十进制计数器级联。四个输入端口:时钟脉冲CLK、使能端EN、清零端CLRN、档位状态端STAT[1:0]。五个输出端口:四个四位十进制BCD码输出OUT1[3:0]~OUT4[3:0]、过量程溢出OF。功能表见下:表格1十进制计数器功能表每个十进制计数器用VerilogHDL语言编程实现。源程序如下:modulecounter_10(clk,en,clrn,cr,out);//clk:时钟脉冲,上升沿触发en:使能端,高电平有效//clrn:清零端,上升沿,高电平有效inputclk,en,clrn;/cr:进位端CLKENCLRNSTAT[1:0]OUT4~1OFHL0,1,23位加一计数OF等于第三位进位HL34位加一计数OF等于第四位进位×LL×计数保持L×××LL×H×LL输入输出outputcr;regcr;//四位十进制BCD码输出output[3:0]out;reg[3:0]out;always@(posedgeclkorposedgeclrn)begin//clrn上升沿、高电平清零if(clrn)beginout=0;cr=0;endelsebegin//en为高,模十加一计数,en为低,计数保持if(en)beginif(out9)beginout=out+1;cr=0;endelseif(out==9)beginout=0;cr=1;endelsebeginout=0;cr=0;endendelsebeginout=out;cr=0;endendendendmodule3.2分频器分频器是本系统最重要的功能部件之一,由它产生闸门电平和控制器、计数器的控制脉冲。它有四个输入:标准时钟脉冲输入CLK1024、溢出处理触发TRIGGER、复位触发RESET和档位状态STAT[1:0]。三个输出:计数闸门电平FGATE、控制器工作脉冲FTRIGGER、计数器控制器清零脉冲FCLR。分频器采用计数分频的办法,即使用一内部寄存器,在时钟脉冲上升沿加一计数,当计到一定值时就改变FGATE的状态,从而达到分频的目的。由于输入标准时钟脉冲为1024Hz,要得到0.1s的FGATE计数值相当小,约为20,误差很大,故在实际设计中把第四档闸门电平时间调整为0.1s,这样第三、四档公用一个闸门电平,同时在计数和锁存时要做相应的移位,因为测量第四档频率时有4位有效数字。要得到10s、1s、0.1s三个FGATE,分别要计数到10240、1024和103。分频器由这三种计数器并联组成,通过3个4选1选择器(一个74LS153和一个4_1MUX),由STAT[1:0]选择使用的FGATE、FCLR和FTRIGGER。出FGATE送计数器EN作为计数器使能闸门电平。FTRIGGER送控制器TRIGGER作为控制器工作脉冲。FCLR送计数器CLRN作为每次计数开始前的清零信号,送控制器CLR作为控制器内部触发信号。这三个信号的时序图3:图3信号时序图由图可以看出FGATE由高变低,即计数结束时,FTRIGGER信号才产生,这时控制器开始工作,判断计数是否有效,然后发出一系列指令直到FCLR信号到来,计数器清零,准备进入下一次计数。采用这样的像CPU时钟一样的信号的原因,一方面,处理计数数据只用了很短的时间,两次测量之间时间很短,加快了频率计的响应速度;另一方面,解决了异步时序逻辑的竞争,使系统工作在异步时序状态下,既保持了很高的响应速度,又有很高的稳定性。为了解决在第一档向第二档转换时等待时间过长的问题,分频器由TRIGGER端口接收一个计数器的溢出脉冲,当计数器溢出时,在脉冲上升沿将内部计数器置为FGATE结束高电平的最后一个计数器值。这样,由于控制器此时溢出已被置位,马上就能进入一次换档处理,保证了换档的快速。另外,RESET信号上升沿到来时,计数器被置为零,这样就可以马上重新开始计数,实现了复位的效果。分频器单元FREQCER_10240的源程序如下(其他两个单元仅计数值不相同,其他均一样,故不列在此,见附录):modulefreqcer_10240(clk,trigger,reset,out_gate,out_clr,out_trigger);inputclk,trigger,reset;outputout_gate,out_clr,out_trigger;regout_gate,out_clr,out_trigger;reg[13:0]counter;always@(posedgeclkorposedgetriggerorposedgereset)begin//计数器溢出,准备进入换档状态if(trigger)begincounter=10239;end//复位elseif(reset)begin//清零,准备开始计数counter=10239;out_trigger=0;out_clr=0;out_gate=0;end//非对称式分频elseif(counter=10239)beginout_trigger=0;out_gate=1;out_clr=0;counter=counter+1;end//连续输出3个TRIGGER和一个CLRelseif((counter=10240)&&(counter=10247))beginif((counter==10241)||(counter==10243)||(counter==10245))out_trigger=1;elseif(counter==10247)out_clr=1;elsebeginout_clr=0;out_trigger=0;endout_gate=0;counter=counter+1;endelseif(counter==10248)begincounter=0;out_gate=0;out_trigger=0;out_clr=0;endendendmodule3.3锁存器锁存器有八个输入:时钟脉冲CLK,置位端SET,复位端RESET,4个4bit十进制BCD输入IN1[3:0]~IN4[3:0],档位状态STAT[1:0]。五个输出:5个5bit十进制BCD输出。由一桥接器BRIDGE和4个LATCH_4_16、1个LATCH_4_1锁存器组成。桥接器BRIDGE主要是为了数据对齐。因为3、4两档使用同一个分频器,故测量第四档时有4位有效数字,通过桥接器转换后就能保证数据有效数字最高位与锁存器第五位对齐。输入输出对应表如下:表格2桥接器功能表STAT=0,1,2STAT=3OUT5=IN3=IN4OUT4=IN2=IN3OUT3=IN1=IN2OUT20=IN1表格3LATCH_4_16功能表输入输出CLKSETRESETOUT00=IN01010F×00×0F锁存器单元LATCH_4_1和LATCH_4_16均为4bit锁存器,其唯一不同在于置位时,LATCH_4_16锁存器内容置为F,另一个置1。下面将LATCH_4_16的功能表(表3)和源程序列出,同样将另一锁存器源程序收于附录。modulelatch_4_16(clk,set,reset,in,out);inputclk,set,reset;input[3:0]in;output[3:0]out;reg[3:0]out;always@(posedgeclkorposedgesetorposedgereset)beginif(set)out=4'b1111;elseif(reset)out=0;elseout=in;endendmodule3.4控制器控制器CONTROLER是整个系统最复杂也是最关键的部件。它由一个控制器核心模块CONTROL_CORE和寄存器OFREGISTER组成。OFREGISTER由CLK端接受计数器溢出脉冲在其上升沿置1,当控制器核心开始换档工作时,通过CLR清除OFREGISTER。其功能表4。表4控制器功能表CONTROL_CORE模块是控制器的核心,有六个输入端口:时序脉冲CLK、清零脉冲CLR、复位脉冲RESET、溢出检测输入OF、计数器输出第3、4位IN3[3:0]和IN4[3:0]。输出端口四个:锁存器工作脉冲LATCH_CLK、OFREGISTER清零脉冲CLROF、锁存器状态LATCH_STAT[1:0]和当前档位状态STAT[1:0]。另外还有寄存器stat_reg[1:0],用在转换档位时临时保存档位。count寄存器,用来标志当前工作脉冲序号。flag寄存器,用来标志当前计数置溢出或不够。reset_reg寄存器,用来标志复位周期。下面根据时序图简要介绍一下工作过程。图4控制器仿真时序图由上述介绍我们知道有三种情况能到达0T状态:计数结束、计数中溢出和复位。这个时候就需要检测。RESET信号在上升沿将reset_reg置为1,并进行复位操作,即状态寄存器分别置值。在1T时刻第工作脉冲到来时,首先检测是不是复位周期,是则跳过,不作任何动作。不是,则检测OF端口是否为1,为1则有溢出,要进行换档,flag标志置1,并发出OFREGISTER清零信号CLROF,没有溢输入输出CLKCLROF×1×0出
本文标题:数字频率计FPGA设计
链接地址:https://www.777doc.com/doc-5236105 .html