机电之家资源网
单片机首页|单片机基础|单片机应用|单片机开发|单片机文案|软件资料下载|音响制作|电路图下载 |嵌入式开发
培训信息
赞助商
基于高速串行BCD码除法的数字频率计的设计
基于高速串行BCD码除法的数字频率计的设计
 更新时间:2009-12-29 16:49:59  点击数:0
【字体: 字体颜色

  摘要: 介绍了在 PPGA 芯片上实现数字频率计的原理。对各种硬件除法进行了比较 , 提出了高速串行 BCD 码除法的硬件算法,并将其应用在频率计设计中。

    关键词: 频率测量 周期测量 FPGA VHDL 状态机

数字频率计是计算机、通讯设备、音频视频等科研生产领域不可缺少的测量仪器。采用 VDHL 编程设计实现的数字频率计,除被测信号的整形部分、键输入部分和数码显示部分以外,其余全部在一片 FPGA 芯片上实现,整个系统非常精简,而且具有灵活的现场可更改性。在不更改硬件电路的基础上,对系统进行各种改进还可以进一步提高系统的性能。该数字频率计具有高速、精确、可靠、抗干扰性强和现场可编程等优点。

在设计中,所有频段均采用直接测频法对信号频率进行测量,克服了逼近式换挡速度慢的缺点;采用了门控信号和被测信号对计数器的使能端进行双重控制,提高了测量的精确度;在运算单元采用了高速串行 BCD 码除法,不仅提高了运算速度,而且减小了资源消耗。

1 系统结构及基本设计原理

以一个 8 位十进制、测量范围为 1Hz~100MHz 的数字频率计为例,采用 100MHz 的标准频率信号,说明设计的基本原理及实现。设计的数字频率计由测量频率模块、计算模块和译码模块组成,如图 1 所示。测频模块采用两个十进制计数器分别测出门控时间内的标准信号和被测信号的周期数 Ns 和 Nx 。计算模块则根据公式 Fx / Nx=Fs/Ns 算出 Fx ,通过译码即可得到被测信号频率的 7 段数码显示。

数字频率计的设计原理实际上是测量单位时间内的周期数。这种方法免去了实测以前的预测,同时节省了划分频段的时间,克服了原来高频段采用测频模式而低频段采用测周期模式的测量方法存在换挡速度慢的缺点。

为克服低频段测量的不准确问题,采用门控信号和被测信号对计数器的使能信号进行双重控制,大大提高了准确度,如图 2 所示。

当门控信号为 1 时,使能信号并不为 1 ,只有被测信号的上升沿到来时,使能端才开始发送有效信号,两个计数器同时开始计数。当门控信号变为 0 时,使能信号并不是立即改变,而是当被测信号的下一个上升沿到来时才变为 0 ,计数器停止计数。因此测量的误差最多为一个标准时钟周期。当采用 100MHz 的信号作为标准信号时,误差最大为 0 . 01 μ s 。

2 高速串行 BCD 码除法运算原理

利用 FPGA 实现二进制除法运算,一种方法是采用逼近法,这种方法速度低、准确性不高。另一种方法是采取被除数与除数的倒数相乘的方法,即将除数作为寄存器的地址,其倒数的小数部分作为寄存器的内容,通过一次寄存器寻址来计算除数的倒数。这种方法在一个时钟周期内即可完成一个完整的除法运算,虽然速度较高,但对于多字节除法运算,不仅程序复杂,而且占用资源较多。根据频率计的实际情况,本设计采用串行除法运算,利用多个时钟周期完成一个完整的除法运算,从而兼顾了频率计对速度和资源两方面的要求。

2 . 1 多位串行 BCD 码减法原理

在数字串行除法运算中,减法运算是必不可少的部分。数字串行 BCD 码的减法运算是将 P 位的 BCD 码分为 P 个宽为 4 的二进制数,然后从低位开始相减,在 P 个时钟周期内完成减法操作。如果输入的操作数位数为 8 ,那么串行 BCD 码减法器可以在 8 个时钟周期内完成 8 位 BCD 码减法运算。

数字串行减法的控制也比较简单, 1 位 BCD 码减法运算完成,进行移位操作,并且移位次数加 1 ,然后通过采用 start 信号指示新计算周期。当移位次数为 n 时,输出移位寄存器完成串/并转换,输出结果。设计者可以根据实际情况,通过选择不同的 n ,提高设计的灵活性。本设计选择 n=8 。

该设计在提高速度的同时,节省了资源。实验证明,采用 1OOMHz 的工作频率,实现一个 8 位 BCD 码串行减法运算,耗用的资源却小于实现 2 位 BCD 码并行减法运算所耗用的资源。

2 . 2 多位串行 BCD 码除法原理

本设计采用循环式除法运算,循环原理可以用下面的公式表示[ 1 ]:

ω[ j+1 ] =r ω[ j ] -dqj+1

式中,ω[ j ]为第 j 步的余数,ω[ 0 ]为被除数; d 为除数 ;qj+1 为第 j+1 步所得的商; r 为与移位步长有关的常数,在此取为 16 。

除法运算循环图表如图 3 所示。

循环步骤如下:

·将ω[ j ]左移四位,构成 r ω[ j ]。

·通过多次 BCD 码减法运算,求得部分商 qJ+1 ,得到部分余数。

·部分余数、部分商移位,准备下次循环。

高速串行 BCD 码除法是建立在 BCD 码减法运算基础上的循环运算。用被除数减除数得到部分余数的 BCD 码,如果够减,则使商加 1 ;否则,余数和商同时左移四位,并记录移位的次数 m ,根据对有效位数的不同要求,可以对 m 进行赋值,如果要求保留 8 位有效数字,则 m=8 。

在这种循环除法运算中,减少循环的次数是提高运算速度比较有效的方法。在一般循环式除法运算中,是从低位开始进行循环相减,循环次数等于商。如果是 8 位除法运行,则得到一个 8 位的商,要进行 8 位次的 BCD 码减法循环,例如: 56895230 / 8=7111903 . 8 ,要进行 7111903 . 8 次循环,计算的速度可想而知。

在本设计中借鉴了一般十进制除法的运算方法,从高位开始相减,大大减少了循环次数。下面以一个例子说明它的原理:

·将被除数和除数移位,使其第一位 BCD 码不为 0000 ,并记录移位的次数 P( 例如: 56895230


参考链接:http://www.picavr.com/news/2008-02/3798.htm

  • 上一篇: 基于AS8228的单相电子式电能表设计
  • 下一篇: 没有了
  • 发表评论   告诉好友   打印此文  收藏此页  关闭窗口  返回顶部
    热点文章
     
    推荐文章
     
    相关文章
    网友评论:(只显示最新5条。)
    关于我们 | 联系我们 | 广告合作 | 付款方式 | 使用帮助 | 机电之家 | 会员助手 | 免费链接

    点击这里给我发消息66821730(技术支持)点击这里给我发消息66821730(广告投放) 点击这里给我发消息41031197(编辑) 点击这里给我发消息58733127(审核)
    本站提供的机电设备,机电供求等信息由机电企业自行提供,该企业负责信息内容的真实性、准确性和合法性。
    机电之家对此不承担任何保证责任,有侵犯您利益的地方请联系机电之家,机电之家将及时作出处理。
    Copyright 2007 机电之家 Inc All Rights Reserved.机电之家-由机电一体化网更名-声明
    电话:0571-87774297 传真:0571-87774298
    杭州滨兴科技有限公司提供技术支持

    主办:杭州市高新区(滨江)机电一体化学会
    中国行业电子商务100强网站

    网站经营许可证:浙B2-20080178-1