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

时间:2025-09-09  作者: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。该运算器适用于高速大数据量的数据处理。

猜您喜欢

干燥剂是常见的吸湿材料,应用于生活和工业中。其主要作用是吸收周围环境中的水分,防止潮湿对物品造成损害。在家庭中,干燥剂常用于食品包装、药品存储以及电子产品的保护...
2008-11-27 00:00:00

采样电阻作为电流检测和电路保护的重要组成部分,是关键配件。随着市场上采样电阻品牌的增多,选择一个可靠且性能优越的品牌变得尤为重要。LIZ(丽智)作为近年来崭露头...
2014-01-05 12:27:15

贴片电阻数值下面的线表示电阻的阻值精度。不同数量和位置的线代表不同的精度等级。最常见的情况是一条线位于数字中间或末尾,这表示电阻的精度为±1%。例如,标有100...
2024-11-29 10:26:18


贴片电阻的型号规格看似复杂,其实掌握规律后很容易区分。主要通过印在表面的数字或字母代码来识别。三位数代码: 最常见的一种,例如「102」。前两位数字代表有效数字...
2025-04-14 15:03:24

贴片电阻体积小巧,焊接牢固,拆卸时需要一定的技巧,才能避免损坏电路板或元件。以下是一些常用的贴片电阻拆卸技巧:使用热风枪:这是最常用的方法,热风枪可以均匀加热贴...
2024-11-29 10:26:10

连接器附件在现代电子设备中是不可少的配件。主要用于提高连接器的性能和稳定性,确保数据传输的准确性和安全性。通过使用这些附件,可以有效防止信号干扰和电磁干扰,提升...
2024-01-20 00:00:00

肖特基二极管因其独特的特性而在现代电子设备中得到了应用。与传统的PN结二极管相比,肖特基二极管具有更低的正向压降和更快的开关速度,这使其在许多领域成为首选。本文...
2025-04-08 06:30:02

电磨组/电磨组套是现代手工艺和工业加工中不可少的工具,其参数直接影响使用效果和工作效率。电磨的功率通常在100W到500W之间,功率越大,适用于更硬的材料,切削...
2023-03-12 00:00:00

监控电源适配器说明书为了确保您安全、正确地使用本产品,请在使用前仔细阅读本说明书,并妥善保管以备日后参考。一、产品概述本产品是一款专为监控设备设计的电源适配器,...
2024-04-24 00:00:00