基于EP1C6Q240C8芯片和CORD IC算法实现自然对数变换器的应用方案

时间:2025-05-02  作者:Diven  阅读:0

引言

基于EP1C6Q240C8芯片和CORD IC算法实现自然对数变换器的应用方案

在需要硬件实现对数运算的场合,其精度和速度是必须考虑的问题。目前硬件实现对数变换的方法主要有查表法、泰勒公式展开法和线性近似法。查表法所需要的存储单元随着精度的增加或输入值范围的增大而成指数增加;泰勒公式展开法需要乘法器,面积大不易实现;线性近似法的精度有限,且需要误差校正电路,实现较难。

本文利用CORD IC算法在FPGA上实现了高速自然对数变换器。CORD IC算法即坐标旋转数字计算方法最初由J.D.Volder于1959年提出,其基本思想是用一系列与运算基数相关的角度的不断偏摆从而逼近所需旋转的角度。1971年J.S.Walter提出统一的CORD IC算法,把圆周旋转、直线旋转和双曲旋转统一到同一个CORD IC迭代方程里,为同一硬件实现多功能运算提供了前提。由于将许多复杂的算术运算化成简单的加法和移位操作,在不影响运算速度和精度的情况下,极大的降低了硬件设计的复杂性,节约了硬件资源。利用CORD IC算法可以直接实现乘法、除法、正余弦函数,反正切函数、双曲函数等,对输入进行适当的初始化可以实现正切、双曲正切、对数和指数等函数。

在数字信号处理领域用的较多的是DSP和FPGA。DSP的优势源于多数信号处理算法的乘-累加运算(MAC)都是非常密集的。FPGA通过多极流水线架构也能够用来实现MAC单元,并且FPGA技术可以通过一个芯片上的多级MAC单元来提供更多的带宽,速度可以比数字信号处理芯片快,并且功耗较低。CORD IC算法完全由移位和加法操作完成,因此利用FPGA可以实现更高的运算速度。本文采用流水线结构在FPGA上实现基于CORD IC的对数变换,可以达到80MHz的处理速度。

CORD IC算法实现自然对数运算

CORD IC算法最初是用于计算三角函数的,后来由于其算法的简单、硬件易于实现等多种优势,而被的用于多种初等函数的运算中(包括三角函数、乘除法运算、指数运算、对数运算等)。本文主要利用CORD IC算法的双曲旋转法实现自然对数运算。

在双曲坐标系下,CORD IC算法的迭代方程为:

由于 ,所以迭代序列必须从n=1开始,为保证迭代序列收敛,因此迭代序列n的取值从第4项开始每隔3n+1项必须重复一次,即n=1,2,3,4,4,5,…,40,40,…。

在向量模式下,经n次迭代后的输出方程为:

因为

所以令x=t+1,y=t-1

所以对于t,如果我们要求lnt,只要做如下初始化:

X=t+1,y=t-1,z=0

则输出z=0.5ln(t),只需要在CORD IC之后做一次左移即可。

如(2)式所示,为保证迭代序列的收敛,|tanh-1(y0/x0)|≤1.1182,因此|y/x|max≈0.8069,n→∞,反双曲正切的定义域为(-1,1),可见函数的输入范围受到了限制。解决的方法是增加n为负数的迭代,改进的算法公式为:

当n≤0时

当n》0时

收敛的范围变成

|tanh-1(y/x)|≤θmax

其中

当M=5时,θmax=12.4264,函数tanh-1的范围是[-12.4264,12.4264]。也就是说此时y/x可以接近于[-1,1],几乎覆盖tanh-1的整个定义域。因此硬件实现过程中可以从-5开始迭代。

对数运算的FPGA实现

CORD IC算法完全由移位和相加完成,很容易在硬件上实现。由于FPGA具有并行处理能力,利用FPGA实现对数变换,速度可以比数字信号处理芯片快,以满足某些高速处理的要求。本文采用的FPGA芯片是Altera公司的cyclone系列芯片EP1C6Q240C8。该芯片内部共有逻辑单元5980个,支持近12万门的设计,内部嵌有约12Kbyte的RAM,包含2个生成时钟的锁相环,最大用户I/O数185个,满足设计要求。

实现方法

· 预处理单元

欲利用CORD IC方法求自然对数,必须对输入进行初始化,经迭代运算后才能得到对数运算值。该对数变换器的输入为16位数,在预处理单元中将输入分别加减一,并将位宽扩大为40位,最高位作为符号位覆值给第一次迭代的x0和y0,如图1所示,图中s代表符号位。扩大位宽可以提高输出精度。

图1初始迭代值x0,y0

· CORD IC单元

CORD IC单元是实现对数变换器的核心。本文利用流水线结构实现CORD IC算法,其结构如图2所示。在设计中,采用由28级CORD IC运算单元组成的流水线结构,为扩大输入范围,从n=-5开始迭代,移位序列为[7,6,5,4,3,2,1,2…28]。前6级根据(3)式进行迭代,后22级根据(4)式进行迭代。经过28级流水线运算后,y变为0,z左移一位就是要求的对数值。每一级电路结构主要包括2个移位寄存器和3个加减法器,这些移位寄存器各自有不同的固定的移位次数,加减法选择由该级中y的最高位(符号位)决定。θn为第n次迭代的旋转角度,并作为常数直接连到了累加器上,不需要存储空间和读取时间。

图2 CORDIC流水线结构

· 后处理单元

由CORD IC得到的z=1/2ln(t),因此将结果左移一位,并截取高16位作为最终的输出。其中最高位为符号位,最大输入值65535的对数值为11.0903,对应的输出为7FFF,其余输出均除以对应的值即得到相应的对数值。

实验结果

在Quartus II 5.1软件环境下使用Verilog HDL语言完成了上述各算法,并在cyclone系列芯片EP1C6Q240C8上实现。图3 为对数运算时序仿真图。表1为对数运算结果与理论值的比较。

图3对数运算时序仿真图

由表1可看出,该对数运算器的输出误差为10-4数量级。由于采用流水线结构,能够在执行进程的同时输入数据,从而极大的提高了程序的运行效率。该设计需要30个时钟周期获取第一个计算结果,而只需要一个时钟周期来获取随后的计算结果。利用Quartus Ⅱ5.1软件进行时序分析,该运算器的最高频率可达到80MHz。该运算器适用于高速大数据量的数据处理。

表1对数运算结果与理论值的比较

结语

利用对数变换可以将乘除法变换为加减法实现,有利于乘除法在硬件中的实现。由于CORD IC算法完全由移位和相加运算完成,降低了复杂性,易于硬件的实现。利用CORD IC算法在FPGA上设计了自然对数变换器。实现过程中采用流水线结构,提高了系统的运行效率。实验结果表明该对数运算器的输出误差为10-4数量级,最高频率可达到80MHz。该运算器适用于高速大数据量的数据处理。

猜您喜欢

直插电阻作为电子元器件中最常见的一种,应用于电路设计与开发中。通常用于限制电流、分压以及信号调节等功能。科技的进步,直插电阻的封装形式也在不断演变,以满足不同的...
2025-03-18 02:00:02

贴片电阻0207,别看它身材小巧,却是电子电路中不可或缺的重要元件。它指的是尺寸为0.02英寸长,0.07英寸宽的矩形贴片电阻,也就是我们常说的0207封装。这...
2024-11-26 11:29:30

平口袋因其简单实用的设计,应用于多个领域。在日常生活中,平口袋常用于购物袋、礼品袋和包装袋,方便人们携带各种物品。在工业领域,平口袋被用于包装食品、药品和化工产...
2009-12-02 00:00:00

电子元器件中,二极管是常见且重要的器件,应用于整流、开关和信号调制等领域。随着时间的推移,二极管可能会出现故障,因此了解如何测量二极管的性能是每个电子爱好者和工...
2025-04-10 06:31:40

自恢复保险丝(Polyfuse)因其能够在过载或短路时自动断开电路,保护设备安全而被应用。曼宣(Manxuan)作为自恢复保险丝领域的知名品牌,其产品在市场上占...
2021-09-27 11:16:30

以太网供电 (PoE) 是一种革命性的技术,允许通过一根以太网电缆同时传输数据和电力。这对企业和个人来说都非常方便,因为消除了对单独电源线和插座的需求。但是,P...
2024-02-19 00:00:00


分流器(Shunt)作为关键的测量工具,是非常重要的配件。特别是在高精度电流测量、电池管理以及电流传感等领域,分流器的性能直接影响系统的准确性和可靠性。本文将深...
2016-10-23 05:46:17

馈电/射频绝缘子作为现代电力系统中不可少的重要组件,具有多项显著优势。具备很好的绝缘性能,能够有效防止电流泄漏,确保电力系统的安全稳定运行。馈电/射频绝缘子采用...
2022-07-25 00:00:00

贴片电阻上的「E01」并不是直接代表阻值,而是代表阻值的代码,需要根据一定的规则进行解码。E01通常表示0.1Ω的阻值,即十分之一欧姆。贴片电阻的阻值代码通常采...
2024-11-26 11:30:01