QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 14948|回复: 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 编辑 % h- }' I" s  J8 C/ B+ m6 U
    % K3 V- g: S9 M$ A
    不知道有木有人研究这个,比较偏向于硬件描述。2 M# h- f* v/ u; @4 J
    今天先发一个sine cose函数的实现。  {/ u9 ?/ B5 t8 F
    有兴趣的可以看一下,m文件见附件。' k  H4 r& d& l3 [4 n5 ?
    function v=f_cordic(beta,n)4 x$ N& X+ {, }4 B
    if beta < -pi/2 || beta > pi/2
    / C3 L7 G! d; x4 j7 \3 {; u! c    if beta < 0/ x8 u. G7 D" R: f0 G- h
            v=f_cordic(beta + pi,n);
    % Z$ j4 @8 l3 o0 ^9 h# I    else
    ; ?' U. p3 D6 L" z) q/ N8 i        v=f_cordic(beta - pi,n);& j$ X4 \; j" {8 y% B
        end4 ?9 H, Z4 ^6 W
        v = -v;% flip the sign for second or third quadrant
    ) ?; K" {. v: |2 e, W1 r    return3 ?, k5 Q& h5 l
    end
    7 ?1 g2 w7 h4 q4 n6 S' |% Initialization of tables of constants used by CORDIC0 B% a* x6 C! G- J- m2 K
    % need a table of arctangents of negative powers of two, in radians:
    # H  u1 a7 z* P% E6 A/ R$ \; ~% angles = atan(2.^-(0:27));
    & J' I2 _1 K& E/ L% Q1 Zangles =  [  ...
    . b" G+ T2 f- E    0.78539816339745   0.46364760900081   0.24497866312686   0.12435499454676 ...
    " X, O( f3 I9 ~7 p- ?- ~& N6 _    0.06241880999596   0.03123983343027   0.01562372862048   0.00781234106010 ...
    ; T' {8 K' [$ Y& c* X% f( p+ [    0.00390623013197   0.00195312251648   0.00097656218956   0.00048828121119 ...
    0 n. l, v0 ^1 a6 `* Y1 b9 {9 N    0.00024414062015   0.00012207031189   0.00006103515617   0.00003051757812 ...2 R- z' j1 _6 ?; D! o3 ^6 f$ P
        0.00001525878906   0.00000762939453   0.00000381469727   0.00000190734863 ...& g3 h; w/ c8 U3 {
        0.00000095367432   0.00000047683716   0.00000023841858   0.00000011920929 ...
    6 d# F6 t+ v0 k! S    0.00000005960464   0.00000002980232   0.00000001490116   0.00000000745058 ];
      v( i& q9 v3 [2 v- K' V" W5 l# ^% and a table of products of reciprocal lengths of vectors [1, 2^-j]:
    1 W7 `: Z$ `, rKvalues = [ ...
    ) R7 J5 T1 R) ?1 x- t5 o% L    0.70710678118655   0.63245553203368   0.61357199107790   0.60883391251775 ...9 G* h3 I$ ~! w  d
        0.60764825625617   0.60735177014130   0.60727764409353   0.60725911229889 ...$ P/ y2 O8 B4 {8 H# {
        0.60725447933256   0.60725332108988   0.60725303152913   0.60725295913894 ...# x0 [& f# A! _/ z1 A  [0 \) B! z8 s
        0.60725294104140   0.60725293651701   0.60725293538591   0.60725293510314 ...5 F; f! T/ k7 \" J
        0.60725293503245   0.60725293501477   0.60725293501035   0.60725293500925 ...
    , h  k4 S6 D9 U) M4 N9 i    0.60725293500897   0.60725293500890   0.60725293500889   0.60725293500888 ];' `( Z  v/ V; k! s6 ]# c- m
    Kn = Kvalues(min(n, length(Kvalues)));& Z. l( n  q" ]4 x
    " k! g$ @) P9 @
    % Initialize loop variables:
    4 p2 t! ^% V; r7 _5 v( d: E1 Iv = [1;0]; % start with 2-vector cosine and sine of zero+ I9 F* G1 c# A7 L, O
    poweroftwo = 1;
    9 O9 u3 `1 Y/ @+ Z7 h! z% Iterations$ A+ H8 `- R3 B' e
    for j = 1:n;
    ! X  C! b2 B- P( I1 J    if beta < 0' L  |+ @* Q6 x! B0 v1 q% ]1 l
            sigma = -1;
    / j" l/ I; r' E    else9 X& |6 \" D% C, E0 r1 V+ ^
            sigma = 1;1 y- d9 k" b# ~) N$ ~# s5 u
        end
    : t: L$ p: b) S1 {$ Y    % update the angle from table, or eventually by just dividing by two' a- j" _5 R/ b/ _& y
        if j <= length(angles)0 i, @+ `; p3 R! b1 t( E- e
            angle = angles(j);' p# c* ~5 U) l
        else
    + V. H. Q5 l' e& A4 v2 L0 w        angle = angle/2;# K* H& p2 `$ p$ ^" s
        end  U' j+ e4 N- c; U$ c
        factor = sigma * poweroftwo;) Z/ ^' \; F7 D5 N5 q7 f. \
        R = [1, -factor; factor, 1];
    ) y& j! B# h1 v    v = R * v; % 2-by-2 mtrix multiply; u, [+ y- b8 f, E, z  N
        beta = beta - sigma * angle; % update the remaining angle3 P: G2 j  a; L5 ~: B, R
        poweroftwo = poweroftwo / 2;$ p* o, @, [6 C( G; C1 ?6 h0 M7 H
    end
    # Z3 k! w% v, _% Adjust length of output vector to be [cos(beta), sin(beta)]:
    ) Z" v2 t' y" r8 Hv = v * Kn;
    ! i% H1 [2 }$ j+ ]/ b' W  W. z$ Zreturn) {4 h1 C  E9 M+ C0 E

    3 H! N; B; _7 B# ]7 G0 ?使用20位寄存器,仿真波形如下:6 f( i' M; E: X( v! M* v, s
    仿真波形
    . m9 {: s/ z9 I  K% }

    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 0 O7 b2 y( n- m+ G+ }7 F1 g8 @
    这是什么算法?第一次听说

      V( X, W! M! ?6 A3 q% k* T' N这个,就是那个。感兴趣的话你还是自己搜搜吧。
    我正在用金山快盘。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 # y/ D4 e, S7 Y: G4 K8 e2 h% E2 y
    我表示很给力

    3 i# q' Y3 X, y0 I! \给力就好。呵呵
    我正在用金山快盘。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的每日心情
    奋斗
    2025-12-13 17:58
  • 签到天数: 3589 天

    [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-4-10 01:13 , Processed in 1.764649 second(s), 106 queries .

    回顶部