QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 15058|回复: 30
打印 上一主题 下一主题

CORDIC算法的matlab实现

[复制链接]
字体大小: 正常 放大
大笨象 实名认证       

42

主题

11

听众

2119

积分

di_dar

  • TA的每日心情
    无聊
    2015-1-15 22:05
  • 签到天数: 79 天

    [LV.6]常住居民II

    自我介绍
    隐秘盛开

    优秀斑竹奖 新人进步奖 发帖功臣

    群组Matlab讨论组

    群组数学趣味、游戏、IQ等

    群组数学建模

    群组SIMULINK

    群组LINGO

    跳转到指定楼层
    1#
    发表于 2011-6-7 11:12 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta
    本帖最后由 大笨象 于 2011-6-7 12:26 编辑
    6 J# \4 {  V: ?1 ^( h2 g( w, i5 h( m$ R; a' M! G" h
    不知道有木有人研究这个,比较偏向于硬件描述。
    + ~$ |+ w5 N# l0 w今天先发一个sine cose函数的实现。$ R* y& g! I; Y, q
    有兴趣的可以看一下,m文件见附件。
    + g8 U1 T; V% H' `# c5 {1 ^function v=f_cordic(beta,n)
    9 G# N+ X9 `* e9 Mif beta < -pi/2 || beta > pi/2. D, X/ a) P+ G0 k; q, P
        if beta < 05 G$ `3 f/ p  B( i1 w: B2 q  ]- E/ u
            v=f_cordic(beta + pi,n);) o2 X: g5 {- W* u2 c8 K
        else3 D( U- W$ F3 B' t% n$ g
            v=f_cordic(beta - pi,n);: p- I0 k( t! s: N3 T3 v
        end$ L; R) [3 ?+ o  G
        v = -v;% flip the sign for second or third quadrant
    ' x" B# f  R& r4 c1 ?4 |    return& T; H* }: A/ Z$ K4 p
    end
    ; o0 q0 m+ @% U5 m' A" t" H% Initialization of tables of constants used by CORDIC
    % N; e( m; {' T1 ^% ?! m3 k  M/ y/ z% need a table of arctangents of negative powers of two, in radians:% s, E8 ^. E7 H7 {) k% J
    % angles = atan(2.^-(0:27));$ \) j- s5 b; n
    angles =  [  ...
    , Z# Q* j) F4 Q# W8 u    0.78539816339745   0.46364760900081   0.24497866312686   0.12435499454676 ...% e1 E4 G1 g# K7 s% F
        0.06241880999596   0.03123983343027   0.01562372862048   0.00781234106010 ...
    $ X8 [/ [: s3 r% L    0.00390623013197   0.00195312251648   0.00097656218956   0.00048828121119 ...
    ! k0 @. }9 Q! ^8 ~  D    0.00024414062015   0.00012207031189   0.00006103515617   0.00003051757812 ...
    $ j- A  u" P7 |4 A: c; P    0.00001525878906   0.00000762939453   0.00000381469727   0.00000190734863 ...2 ?1 e" i/ F7 _* j! w& x
        0.00000095367432   0.00000047683716   0.00000023841858   0.00000011920929 ...
    9 {$ X' e+ {" Z$ h. t* L8 R    0.00000005960464   0.00000002980232   0.00000001490116   0.00000000745058 ];* ~+ `) O7 w% r6 c8 D
    % and a table of products of reciprocal lengths of vectors [1, 2^-j]:6 i0 ]9 ^2 W* J: Z
    Kvalues = [ ...6 d0 U* O1 j# l0 q2 r
        0.70710678118655   0.63245553203368   0.61357199107790   0.60883391251775 ...0 _' r+ m3 @) s6 z
        0.60764825625617   0.60735177014130   0.60727764409353   0.60725911229889 ..., z' U8 V& m6 u2 T& L2 w
        0.60725447933256   0.60725332108988   0.60725303152913   0.60725295913894 ...4 k+ d4 Y* o0 j6 ^: Q) s
        0.60725294104140   0.60725293651701   0.60725293538591   0.60725293510314 ...- E. x! J1 U2 P- ~. b8 l- w' [. g
        0.60725293503245   0.60725293501477   0.60725293501035   0.60725293500925 ...
      w5 l* `! L- [; A8 s$ P    0.60725293500897   0.60725293500890   0.60725293500889   0.60725293500888 ];+ J, _" Y+ h. q2 V  }1 N8 u
    Kn = Kvalues(min(n, length(Kvalues)));
    , X9 M4 I7 f/ ~- I+ a! y% c 6 f. `1 E. @* I# W
    % Initialize loop variables:
    7 o/ E$ Y& q7 p  g/ w/ Zv = [1;0]; % start with 2-vector cosine and sine of zero) B7 m  W7 b6 v8 o! x: I
    poweroftwo = 1; % {$ F7 @* l$ Q6 N
    % Iterations
    0 O2 v9 ?- K# L9 gfor j = 1:n;
    + b; `# W$ [) P0 H7 M, D% z, X    if beta < 0
    8 N! Y% X, b$ x  \: j" U" z$ Q- q. p        sigma = -1;
    ( a$ ?$ J$ j: l+ j2 i    else
    8 M0 p  y* H& m" y        sigma = 1;
    * X, m* }0 d% p* {: S4 ?7 }    end: @/ H' G; R4 C% C
        % update the angle from table, or eventually by just dividing by two' I  C9 |0 ]. o) m0 w7 n
        if j <= length(angles)
    4 b3 I  c5 I! l/ n: g: N9 P; T! g        angle = angles(j);1 {) }; F: c4 \- c! R# N
        else
    ! t) C; L& j- Z; F) s1 @        angle = angle/2;
    " L, u3 c/ D/ o- c* d6 U, ]( B2 C    end, N, Z& M( ^5 @5 k
        factor = sigma * poweroftwo;+ N4 y* o) n; l$ L( U* U
        R = [1, -factor; factor, 1];: E3 ~, R+ R3 W& ?. n; B
        v = R * v; % 2-by-2 mtrix multiply
    " J# M; e# y6 V8 c, d& x    beta = beta - sigma * angle; % update the remaining angle, g8 c/ X8 V3 x: H- U
        poweroftwo = poweroftwo / 2;
    9 ^  E4 k, E- i6 E1 L( s6 nend
    ( B% y6 ^( c8 @3 f% Adjust length of output vector to be [cos(beta), sin(beta)]:2 f9 r; P0 m5 q7 b3 ]# {+ S- R
    v = v * Kn;
    4 n/ h- R  O, G/ mreturn5 O# v- w2 ?. H: i& H% O
    , c( x- o# h3 X! T2 r7 H
    使用20位寄存器,仿真波形如下:
    * ]; _3 D" }5 D 仿真波形 9 B' R: c, o" _; Z3 T0 p1 w4 J

    f_cordic.m

    2.25 KB, 下载次数: 21, 下载积分: 体力 -2 点

    CORDIC算法

    点评

    Ling619400  给力  发表于 2015-2-1 22:31
    zan
    已有 2 人评分体力 收起 理由
    sdccumcm + 5 很给力!
    厚积薄发 + 5 赞一个!

    总评分: 体力 + 10   查看全部评分

    转播转播0 分享淘帖0 分享分享1 收藏收藏2 支持支持3 反对反对0 微信微信
    我正在用金山快盘。http://www.kuaipan.cn/?channel=6ohsg7
    杨帆 实名认证       

    4

    主题

    4

    听众

    626

    积分

    升级  6.5%

  • TA的每日心情
    奋斗
    2012-12-4 13:38
  • 签到天数: 314 天

    [LV.8]以坛为家I

    新人进步奖 最具活力勋章 发帖功臣

    群组数学趣味、游戏、IQ等

    群组数学建模

    群组我们一定会赢

    回复

    使用道具 举报

    1

    主题

    3

    听众

    453

    积分

    升级  51%

  • TA的每日心情
    开心
    2015-7-7 09:53
  • 签到天数: 50 天

    [LV.5]常住居民I

    群组华南理工大学

    群组Matlab讨论组

    群组狂热数模爱好者

    群组数学建摸协会

    群组学术交流A

    回复

    使用道具 举报

    赛才        

    0

    主题

    2

    听众

    46

    积分

    升级  43.16%

    该用户从未签到

    回复

    使用道具 举报

    大笨象 实名认证       

    42

    主题

    11

    听众

    2119

    积分

    di_dar

  • TA的每日心情
    无聊
    2015-1-15 22:05
  • 签到天数: 79 天

    [LV.6]常住居民II

    自我介绍
    隐秘盛开

    优秀斑竹奖 新人进步奖 发帖功臣

    群组Matlab讨论组

    群组数学趣味、游戏、IQ等

    群组数学建模

    群组SIMULINK

    群组LINGO

    zhangjichang 发表于 2011-6-8 22:31
    % }) k) b4 Y; c8 `' Q/ x# R这是什么算法?第一次听说
    ( ^- ?! Y! V' l% _6 P
    这个,就是那个。感兴趣的话你还是自己搜搜吧。
    我正在用金山快盘。http://www.kuaipan.cn/?channel=6ohsg7
    回复

    使用道具 举报

    大笨象 实名认证       

    42

    主题

    11

    听众

    2119

    积分

    di_dar

  • TA的每日心情
    无聊
    2015-1-15 22:05
  • 签到天数: 79 天

    [LV.6]常住居民II

    自我介绍
    隐秘盛开

    优秀斑竹奖 新人进步奖 发帖功臣

    群组Matlab讨论组

    群组数学趣味、游戏、IQ等

    群组数学建模

    群组SIMULINK

    群组LINGO

    赛才 发表于 2011-6-9 15:01
    3 {. ?7 c* j+ C$ L我表示很给力
    2 {0 U. W- g- _7 Q
    给力就好。呵呵
    我正在用金山快盘。http://www.kuaipan.cn/?channel=6ohsg7
    回复

    使用道具 举报

    1

    主题

    2

    听众

    48

    积分

    升级  45.26%

  • TA的每日心情

    2011-7-1 22:07
  • 签到天数: 10 天

    [LV.3]偶尔看看II

    自我介绍
    最强的人往往是含泪奔跑的人!!!

    群组C 语言讨论组

    群组东北三省联盟

    群组数学专业考研加油站

    群组数学建模

    回复

    使用道具 举报

    yingzhen        

    1

    主题

    3

    听众

    297

    积分

    升级  98.5%

  • TA的每日心情

    2011-12-18 20:51
  • 签到天数: 30 天

    [LV.5]常住居民I

    回复

    使用道具 举报

    羅雲琦        

    5

    主题

    2

    听众

    603

    积分

    升级  0.75%

  • TA的每日心情
    开心
    2014-11-2 16:11
  • 签到天数: 237 天

    [LV.7]常住居民III

    自我介绍
    我是來自四川省合江縣的男孩,樂觀自信

    社区QQ达人

    群组科技写作基础培训

    群组2011年第一期数学建模

    群组第四届cumcm国赛实训

    群组学术交流A

    群组学术交流B

    回复

    使用道具 举报

    jt202010 实名认证    中国数模人才认证  会长俱乐部认证 

    109

    主题

    165

    听众

    1万

    积分

    升级  0%

  • TA的每日心情
    擦汗
    2026-5-21 15:46
  • 签到天数: 3604 天

    [LV.Master]伴坛终老

    社区QQ达人 邮箱绑定达人 最具活力勋章 发帖功臣 风雨历程奖 新人进步奖

    群组数学建模

    群组自然数狂想曲

    群组2013年数学建模国赛备

    群组第三届数模基础实训

    群组第四届数学中国美赛实

    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-5-25 07:12 , Processed in 0.407816 second(s), 106 queries .

    回顶部