基于FPGA的等精度数字频率计设计(修订版)
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
基于FPGA的等精度数字频率计设计
微电子学与固体电子学
张嘉伟113114312
目录
摘要 (3)
第一章课题背景 (4)
第二章方案设计及原理 (4)
1 多周期同步测频率测量原理 (4)
2 设计实现 (6)
2.1 FPGA程序设计 (6)
2.2 DSP程序设计 (7)
第三章主要模块的Verilog程序 (8)
1 计数器 (8)
2 除法器 (8)
3 分频器 (11)
4 BCD模块 (11)
第四章仿真结果 (12)
第五章设计总结 (13)
参考文献 (13)
摘要
本文主要论述了利用FPGA进行测量频率计数,FPGA实施控制实现多功能频率计的设计过程。
该频率计利用等精度的设计方法,克服了基于传统测频原理的频率计的测量精度随被测信号频率的下降而降低的缺点。
等精度的测量方法不但具有较高的测量精度,而且在整个频率区域包成恒定的测试精度。
根据多周期同步测频率法的原则,选取了多周期同步测频法作为数字频率计的测量算法,提出了基于FPGA的数字频率计设计方案。
给出了该设计方案的实际测量效果,证明该设计方案切实可行,能达到较高的频率测量精度。
关键词:FPGA;等精度;频率计
第一章课题背景
随着大规模集成电路技术的发展及电子产品市场运作节奏的进一步加快,涉及诸如计算机应用、通信、智能仪表、医用设备、军事、民用电器等领域的现代电子设计技术已迈入一个全新的阶段。
专家预言,未来的电子技术时代将是EDA 的时代,PLD作为EDA技术的一项重要技术,是电子设计领域中最具活力和发展前途的一项技术,它的影响丝毫不亚于70年代单片机的发明和使用。
在电子测量技术中,频率测量是最基本的测量之一。
工程中很多测量,如用振弦式测量力、时间测量、速度测量、速度控制等,都设计到频率测量,或可归结为频率测量。
而常用的直接测量方法在使用中有较大的局限性,其测量精度随着被测信号频率的下降而降低,并且对被测信号的计数要产生±1个数字误差。
采用等精度频率测量方法具有测量精度保持恒定,不随所测信号的变化而变化;结合FPGA,具有集成度高、告诉和高可靠性的特点,是频率的测频范围可达到0.1Hz-50MHz,测频全域相对误差恒为百万分之一。
第二章方案设计及原理
1 多周期同步测频率测量原理
频率是周期信号在单位时间内的重复次数。
电子计数器可以对一个周期信号发生的次数进行计数。
如果某一信号在Ts时间间隔内的重复次数为N次,则该信号的频率f为
N
F
T
在直接测频率的基础上发展的多周期同步测频率法,在目前的测频系统中得到越来越广泛的应用。
多周期同步法的测频原理如图1所示。
图1 多周期同步法测频原理波形图
首先,由控制线路给出闸门开启信号,此时,计数器并不开始计数,而是等到被测信号的上升沿到来时真正开始计数。
然后,两组计数器分别对被测信号和标准信号进行计数,要等到被测信号下降沿到来时才整整结束计数,以完成1次测量过程。
计数器的开闭与被测信号的完全同步的。
从图1中可以得到闸门时间不是固定的值,而是被测信号的整周期的倍数,即与被测信号同步,因而,不存在对被测信号计数的±1误差,可得到:
x
s
n m f f =
变形后可得:
x s n f f m =
对上式进行微分,可得
2
x s s n n df f dn df m
m
=-
+
由于1dn =±,
x
s
n m f f =
,因而可推出:
1x s x
s
df df f m
f =±+
从式中可以看出:测量误差与被测信号频率无关,从而实现了被测频带内的等精度测量;增大T 或提高s f 可以提高测量精度,标准频率误差为/s s df f ,因为晶体的稳定度很高,标准频率误差可以进行校准,校准后的标准频率误差可以忽略。
被测开始时,首先发出清零信号CLR ,使D 触发器和2个计数器清零,然后预制门控信号变为高电平(开闸门),在被测信号的下一个上升沿到来时,使同部门控信号上升为高电平(开同部门)。
图2 等精度测量原理图
于此同时启动两个计数器CNT1和CNT2,进入“计数允许周期”。
这里我们将启动计数器进入计数操作的信号称为“计数允许信号”。
在此期间,CNT1和CNT2
分别对被测信号(频率为
f)和标准信号(频率为s f)计数。
经过pr T秒后预制
x
门控信号变为低电平,但由于此时Q端仍未高电平,因此2个计数器仍处于“计数允许周期”,直到下一个被测信号上升沿到来,Q端才变为低电平,将2个计数器同时关闭。
可以看出,实际闸门时间与预制闸门时间并不严格相等,但差值不超过被测信号的一个周期。
“计数允许周期”恰好是被测信号周期的整数倍,但不一定是校准频率信号的整数倍。
由于标准频率信号与“计数允许信号”不相关,标准频率信号相对“计数允许信号”使能时间具有随机性,根据传统测频方案的误差分析,计数器CNT1的计数结果会有±1误差。
2设计实现
2.1 FPGA程序设计
FPGA程序框图如图3所示,由同步门D触发器、标准信号计数器、被测信号计数器和64-8多路选择器构成。
其中预置门控信号CL、清零信号CLR、数据输出选择SEL[2..0]由DSP发出,FPGA通过START的下降沿同质DSP计数结束,可以分8次取数。
图3 FPGA结构框图
2.2 DSP程序设计
DSP的主要任务是:
(1)对FPGA整个工作进行控制
(2)接受并且保存FPGA的计数值
(3)对接收来的数据进行转换和加、减、乘、除运算并且数码显示结果(4)完成与PC机的通信
程序设计主要包括多FPGA工作方式、DSP的浮点运算、数据接收、中断显示、中断串口通信等。
其主程序流程图如图4所示。
由于浮点数具有精度高、数的表示范围宽等特点,设计中采用单精度浮点数进行运算。
计算过程中主要用足够长的尾数来保证数据的精度,用阶码来调整整数模(绝对值)的大小(即改变小数点的位置),并自动进行符号处理。
设计中的浮点运算子程序有:浮点加法子程序、浮点乘法子程序、浮点转定子程序;以及数值转换子程序:定点证书二翻十、定点小树二翻十。
由于DSP强大的运算能力,可以保证数据计算过程的快熟和准确,从而保证频率计的高精度与较高的测量速度。
图5 DSP的主程序流程
第三章主要模块的Verilog程序1 计数器
module Counter
(
iclk,
rst_n,
q,
overflow
);
inputiclk;
inputrst_n;
outputreg [3:0] q;
output overflow;
always @(posedgeiclk or negedgerst_n)
begin
if(~rst_n) q <= 4'h0;
else
begin
if(4'h9 == q) q <= 4'h0;
else q <= q + 4'h1;
end
end
assign overflow = 4'h9 == q;
endmodule
2 除法器
module sque_divider(a,b,c,d,done,clk,reset,load,error);
input [7:0]a,b;
input load;
inputclk,reset;
output [7:0]c,d;
outputdone,error;
reg[7:0] c,d;
reg[7:0] a1,b1;
reg[7:0]c1,d1;
regdone,error;
always @(posedgeclk or posedge reset) if(reset)
begin
done<=0;
error<=0;
end
else if(load)
begin
a1<=a;
d1<=0;
b1<=b;
done<=0;
error<=0;
end
else if (b1==0)//(b==0)
begin
error<=1;
end
else if((a1<b)&&(!error))
begin
c1<=a1;
done=1;
end
else if((!done)&&(!error))
begin
d1<=d1+1;
a1<=a1-b;
end
always @(posedgeclk or posedge reset) if(reset)
begin
c<=0;
d<=0;
end
else if(done)
begin
c<=c1;
d<=d1;
end endmodule
timescale 1ns/10ps moduletest_sque_divider;
reg [7:0]a,b;
regclk,reset,load;
wire [7:0]c,d;
wiredone,error;
initial
begin
clk=0;
reset=0;
load=0;
#5 reset=1;
#5 reset=0;
#5
a=50;
b=23;
#3 load=1;
#15 load=0;
#50
a=150;
b=13;
#5 load=1;
#15 load=0;
#150
a=150;
b=0;
#15 load=1;
#15 load=0;
#50
a=150;
b=110;
#5 load=1;
#15 load=0;
end
always #3 clk=!clk;
sque_divider
m1(.a(a),.b(b),.c(c),.d(d),.done(done),.clk(clk),.reset(reset),.load(load),.error(error)); endmodule
3 分频器
module divider(clk_in,enable,reset,clk_out);
inputclk_in,enable,reset;
outputclk_out;
regclk_out;
always @(posedgeclk_in)
if(!reset) clk_out=1'b0;
else
if(enable)
clk_out=!clk_out;
initialclk_out=1'b0;
endmodule
4 BCD模块
module B_BCD(binary,bcd);
parameterB_SIZE=11;
always@(bianry)
begin
bin=binary;
result=0;
begin
repeat(B_SIZE-1)
begin
result[0]=bin[B_SIZE-1];
if(result[3:0]>4)
result[3:0]=result[3:0]+4’d3;
if(result[7:4]>4)
result[7:4]=result[7:4]+4’d3;
if(result[11:8]>4)
result[11:8]=result[11:8]+4’d3;
if(result[15:12]>4)
result[15:12]=result[15:12]+4’d3;
result=result<<1;
bin=bin<<1;
end
result[0]=bin[B_SIZE-1];
bcd<=result;
end
end
endmodule
第四章仿真结果
本系统比较复杂,因此采用自底向上的调试方法,也就是先进行各个单元电路的软件仿真和硬件调试,在各个单元电路调试好后再进行系统调试,最后进行硬件的编程固化及系统的组装。
图5-1 TOP
图5-2 计数模块
图5-3 测频周期模块
第五章设计总结
基于FPGA的等精度频率计的设计,采用Verilog语言,运用自顶向下的设计思想,将系统按功能逐层分割的层次化设计方法。
软件平台是ALTERA公司的QuartusⅡ。
本次设计包括了设计输入、编译、软件仿真、下载和硬件仿真等全过程。
通过本次设计对等精度数字频率计有了深刻的了解,并且自己学习了软件,不仅培养了自学能力,还能更好的运用,受益匪浅。
参考文献
[1]吴海明,王伟.基于单片机与FPGA的等精度频率计设计[J].兵工自动化,2009,28(3):79-81.
[2]莫琳.基于FPGA的等精度频率计的设计与实现[J]。
现代电子技术,2004,10:81-84.
[3]李云鹏,王思明.基于FPGA的等精度频率计设计[J].电子元器件应用,2007,9(11):54-55.
[4]林建英,伍勇.自适应快速高精度数字频率计片上系统设计的实现[J].实验科学与技术,2004,2(1):27-30.
[5]包明,赵明富.EDA技术与数字系统设计[M].北京:北京航空航天大学出版社,2001.。