QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 14949|回复: 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 P, Z) C- v7 H; S( o  G! X) E- I

    , M4 ?( n7 J  f$ S* Y: \不知道有木有人研究这个,比较偏向于硬件描述。+ W+ F( x, t9 _# Z8 q9 A8 M% x
    今天先发一个sine cose函数的实现。
    6 w) J" T. \! X  T9 u5 D有兴趣的可以看一下,m文件见附件。, a4 A  A  r5 U' w$ M
    function v=f_cordic(beta,n)) |9 @2 O+ z" p1 c1 d  j: e
    if beta < -pi/2 || beta > pi/2- k4 v/ a6 ?( @; S* R7 k2 P+ r
        if beta < 04 q  T# x- A! ]; I& m* c
            v=f_cordic(beta + pi,n);
    - x, c  F  ?, u  |. ?$ M: ]    else$ [3 U3 w9 o6 n3 }6 E# l
            v=f_cordic(beta - pi,n);6 u4 u: q$ [1 i* s) |
        end! c! p6 j& C' a; o" h
        v = -v;% flip the sign for second or third quadrant
    & D" X$ a+ u' X& ~& e3 |+ |    return
    * \% A: S1 w3 A3 K# Z+ v5 J0 `end
    % j. l2 t& H' I% Initialization of tables of constants used by CORDIC3 u1 U, f1 n4 ]
    % need a table of arctangents of negative powers of two, in radians:; Q: d; S& w6 S! }4 R4 L
    % angles = atan(2.^-(0:27));
    % U) @% C1 X. ^$ xangles =  [  ...
    $ V+ i; r& u/ W# F. b  o    0.78539816339745   0.46364760900081   0.24497866312686   0.12435499454676 ...  H( L. I( N# E. O
        0.06241880999596   0.03123983343027   0.01562372862048   0.00781234106010 ...
    ( t) S/ R( j: r% X3 R5 i7 o; q    0.00390623013197   0.00195312251648   0.00097656218956   0.00048828121119 .../ m  h! r0 n* p# e" n
        0.00024414062015   0.00012207031189   0.00006103515617   0.00003051757812 ...+ y0 y# Y/ P: @8 g; h
        0.00001525878906   0.00000762939453   0.00000381469727   0.00000190734863 ...
    ' g1 o; L4 m* m5 ?) V2 g& _    0.00000095367432   0.00000047683716   0.00000023841858   0.00000011920929 ...+ [$ t' b8 k0 l
        0.00000005960464   0.00000002980232   0.00000001490116   0.00000000745058 ];
    0 {" `: H; v1 ~! [9 H% and a table of products of reciprocal lengths of vectors [1, 2^-j]:
    ' e3 Y% S! o& Z7 P0 D  IKvalues = [ ...& K1 ~; F* T/ N* o
        0.70710678118655   0.63245553203368   0.61357199107790   0.60883391251775 ...
    ) v  V1 ?& A  A1 M6 l+ J    0.60764825625617   0.60735177014130   0.60727764409353   0.60725911229889 ..., C1 B# O) I0 ^4 ?
        0.60725447933256   0.60725332108988   0.60725303152913   0.60725295913894 ...
    5 I) J4 y3 M  W    0.60725294104140   0.60725293651701   0.60725293538591   0.60725293510314 ...% M, [. f8 F+ k9 n4 B7 f& O: p5 ~6 B
        0.60725293503245   0.60725293501477   0.60725293501035   0.60725293500925 ...
    . p4 {1 Q4 x1 d7 Q8 w" |    0.60725293500897   0.60725293500890   0.60725293500889   0.60725293500888 ];7 h. [: H8 C; v
    Kn = Kvalues(min(n, length(Kvalues)));! T6 I/ ]- g' I7 L2 [" ~
    7 u- ~, F' c. y& b4 F
    % Initialize loop variables:
    1 }# O+ ]; Z. ~9 ^1 wv = [1;0]; % start with 2-vector cosine and sine of zero
      {- L* Y* U/ R% R' Mpoweroftwo = 1;
      s' _" G- ^* _  m4 p& K% Iterations
    2 ~! m8 U; T# j+ }( B7 @for j = 1:n;) c- a3 w- ^" k/ J
        if beta < 0
      m3 c6 k' S. y+ u2 }        sigma = -1;3 F3 N. y. q; ~6 C. a) K
        else" E; D$ _) u" L7 w" h1 |
            sigma = 1;
    + ^# s# A4 e( S0 r# R9 G9 K' t    end% T! w9 T8 ^/ {0 {* z5 X& E3 }) O- x
        % update the angle from table, or eventually by just dividing by two) f- R2 u' a# x; p6 f* {4 `
        if j <= length(angles)
    ( G$ B* G- q- `( |4 D; l        angle = angles(j);
    3 X8 Q9 Z3 t' I. W6 c0 u# T  m    else
    0 |# z1 b( O. l: C6 o, V        angle = angle/2;5 E4 A$ r( E6 R( D4 H& c
        end
    6 m  u4 ]$ [; b+ B, b6 l" K6 c    factor = sigma * poweroftwo;
    7 y. x4 A" K, u# q9 z$ P3 n4 e! p    R = [1, -factor; factor, 1];0 f# Q7 v, P0 Q& A  k; J% d
        v = R * v; % 2-by-2 mtrix multiply
    ; K) K4 L" L0 E    beta = beta - sigma * angle; % update the remaining angle' ^$ D# x* U" ?4 P' {
        poweroftwo = poweroftwo / 2;' h  V- ^5 n7 \# W+ F
    end
    3 @  u: \4 y) h* |) \% Adjust length of output vector to be [cos(beta), sin(beta)]:( }5 d5 @: d% c
    v = v * Kn;( \8 x' Y, U7 P
    return
    - T3 W+ T4 ?9 X, c. L2 k( U( ?+ A  u: L, T6 P  Z+ P+ P/ e! K1 R* E
    使用20位寄存器,仿真波形如下:' ^: ?4 o+ ?  S! ~& Q/ U' g( s
    仿真波形
    . A" T/ a' ?6 W( B8 R+ ?

    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
    4 I3 k- r& H6 j' `9 ?: ]) M6 U, d8 x这是什么算法?第一次听说

    1 Q% `; g1 G* ^% w这个,就是那个。感兴趣的话你还是自己搜搜吧。
    我正在用金山快盘。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 ; q4 Z% y3 [! D* o, p( k8 Z/ N& v
    我表示很给力
    4 L' m. l8 q+ m. \, r& G5 k9 }
    给力就好。呵呵
    我正在用金山快盘。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 02:03 , Processed in 0.659379 second(s), 106 queries .

    回顶部