eeiit的个人空间 https://blog.eetop.cn/63271 [收藏] [复制] [分享] [RSS]

空间首页 动态 记录 日志 相册 主题 分享 留言板 个人资料

日志

CORDIC算法小结

已有 13546 次阅读| 2007-3-26 04:15 |个人分类:算法实现

天气: 晴朗
心情: 高兴

坐标旋转数字计算机CORDIC(COordinate Rotation DIgital Computer)算法通过移位和加减运算,递归计算常用函数值,如sin, cos, sinh, cosh。

以sin/cos计算为例,可利用正/余弦的和角公式递归进行:  

cos(a+b) = cos(a)cos(b) – sin(a)sin(b) = cos(a) [cos(b) – tan(a)sin(b)] 

sin(a+b) = sin(a)cos(b) + cos(a)sin(b) = cos(a) [tan(a)cos(b) +sin(b)]  

取a=arctan(2^-k), 即tan(a)=2^-k, cos(b) – tan(a)sin(b) 可通过移位和减法来实现。

如果角度z可以表示为z = s0 arctan(2^0) + s1 arctan(2^-1) + ... + sn arctan(2^-n), 其 中s0, s1, ..., sn取+1或-1(+1以理解为逆时针转角即加上一个角; -1则相) ,那么角度z的sin/cos计算可以通过一系列的移位和加减运算来实现。注意到cos(sk arctan(2^-k))=cos(arctan(2^-k)) 与转角方向无关。此外,z应取第一项限角度(收敛域),对於其他项限角度,可由其第一项限对应角度变换得到。

 

相类似地,sinh/cosh的计算利用以下公式: 

cosh(a+b) = cosh(a)cosh(b) + sinh(a)sinh(b) = cosh(a) [cosh(b) + tanh(a)sinh(b)]

sinh(a+b) = sinh(a)cosh(b) + cosh(a)sinh(b) = cosh(a) [tanh(a)cosh(b) + sinh(b)] 

a=arctanh(2^-k), tanh(a)=2^-k, 则cosh(b) + tanh(a)sinh(b) 可通移位和减法来实现。如果参数z可以表示为z = s1 arctanh(2^-1) + s2 arctanh(2^-2) + ... + sn arctanh(2^-n), 其 中s1, s2, ..., sn取+1或-1 ,那么z的sinh/cosh计算可以通过一系列的移位和加减运算来实现。

z应取[-ln2, ln2]范围内的值,否则应先预处理 z = z’– pln2, 求得cosh(z’)/sinh(z’)的值,则 

cosh(z) = cosh(z’)cosh(pln2) + sinh(z’)sinh(pln2)

              = ½[cosh(z’) + sinh(z’)]2^p + ½[cosh(z’) – sinh(z’)]2^-p

sinh(z) = sinh(z’)cosh(pln2) + cosh(z’)sinh(pln2)

           = ½[cosh(z’) + sinh(z’)]2^p + ½[sinh(z’) – cosh(z’)]2^-p 。

 

sin/cos和sinh/cosh的计算是CORDIC算法的两个特 例,CORDIC算法可描述如下:

给定初 始值x(0), y(0), z(0),

x(k+1) = x(k) – ms(k)y(k)2^-q(m,k),  y(k+1) = y(k) + s(k)x(k) 2^-q(m,k),  z(k+1) = z(k) – s(k)d(k),  

其中m表示模式,q(m,k) 为移位序列,s(k) 取+1或-1表示旋转方向,d(k) 为递进角度。

 

以cos(a)/sin(a)计算为例,m = 1, x(0) = 1, y(0) = 0, z(0) = a, s(k) = sign(z(k)),移位序列q(1,k): 0, 1, 2, ..., 递进角度为d(k)=arctan(2^-q(1,k)) 。

下面是实现的Matlab程序:

z = a;

x = 0.6072529350;                               % scaled cos(0)

y = 0;                                                   % sin(0)

for i = 1:K

     signZ = sign(z);                           % s(k) for rotation direction  

     xNew = x - signZ*y*2^(-(i-1));

     y = signZ*x*2^(-(i-1)) + y; 

 

    x = xNew;

     z = z - signZ*atan(2^(-(i-1)));    % atan(2^-(i-1)) is included in a look-up table

end

x的初始值为cos(arctan(1)), cos(arctan(2^-1)), ..., cos(arctan(2^-K) 的连积值,收敛为0.6072529350

 

cosh(a)/sinh(a)算为,m = -1, x(0) = 1, y(0) = 0, z(0) = a, s(k) = sign(z(k)),移位序q(-1,k): 1, 2, 3, 4, 4, 5, ... (3n+1重复两次以保证收敛, 4, 13, 40, ...), 递进角度为d(k)=arctanh(2^-q(-1,k)) 。

 

通过对初始值和旋转方向s(k) 的选择,模式m=0可以计算乘法和除法; 模式m=1可以计算sin/cos/arcsin/arccos/arctan; 模式m=-1可直接计算sinh/cosh/exp/arctanh/ln/sqrt, 间接计算arcsinh/arccosh,参见http://archives.math.utk.edu/ICTCM/VOL11/C027/paper.pdf

关于CORDIC的FPGA实现可参考 http://www.fpga-guru.com/files/crdcsrvy.pdf

 

 


点赞

发表评论 评论 (2 个评论)

Guest 2007-4-9 13:50
http://e335e6deb5f2deb94e086b388829b805-t.rh5t5bf.info <a href="http://e335e6deb5f2deb94e086b388829b805-h.rh5t5bf.info">e335e6deb5f2deb94e086b388829b805</a> [url]http://e335e6deb5f2deb94e086b388829b805-b1.rh5t5bf.info[/url] [url=http://e335e6deb5f2deb94e086b388829b805-b2.rh5t5bf.info]e335e6deb5f2deb94e086b388829b805[/url] [u]http://e335e6deb5f2deb94e086b388829b805-b3.rh5t5bf.info[/u] 0c4df95de00b5aa0f800bcc958a3b7df
Guest 2007-5-1 09:38
http://5c9e422954d066069c1fca9d503a7661-t.k90u0h.info <a href="http://5c9e422954d066069c1fca9d503a7661-h.k90u0h.info">5c9e422954d066069c1fca9d503a7661</a> [url]http://5c9e422954d066069c1fca9d503a7661-b1.k90u0h.info[/url] [url=http://5c9e422954d066069c1fca9d503a7661-b2.k90u0h.info]5c9e422954d066069c1fca9d503a7661[/url] [u]http://5c9e422954d066069c1fca9d503a7661-b3.k90u0h.info[/u] 86b4eaaaf8201e29470f084ce1d2d695

facelist

您需要登录后才可以评论 登录 | 注册

  • 关注TA
  • 加好友
  • 联系TA
  • 0

    周排名
  • 0

    月排名
  • 0

    总排名
  • 0

    关注
  • 1

    粉丝
  • 0

    好友
  • 0

    获赞
  • 20

    评论
  • 访问数
关闭

站长推荐 上一条 /1 下一条

小黑屋| 关于我们| 联系我们| 在线咨询| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2024-5-3 01:44 , Processed in 0.026269 second(s), 19 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
返回顶部