QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 14977|回复: 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 编辑
    7 ~2 L3 H, {  i: _1 M! [$ m; ?6 \- x) E6 f. T
    不知道有木有人研究这个,比较偏向于硬件描述。
    ! X% s( Z. o: y今天先发一个sine cose函数的实现。: S% B  i1 ~- K$ ]" ~9 ?; g
    有兴趣的可以看一下,m文件见附件。) \* p- ?1 n# X/ C/ @, F
    function v=f_cordic(beta,n); O0 U% c& n$ S; X. i8 {/ S
    if beta < -pi/2 || beta > pi/2
    $ H1 M) `* I8 n1 S3 p" h3 Q1 x    if beta < 0
    + b- t+ U$ Y! b0 }8 ^  r        v=f_cordic(beta + pi,n);
    8 B* X4 j  G, y' j8 U! q    else
    & b8 z' i8 P. M4 \3 c* D% h        v=f_cordic(beta - pi,n);$ E( v& y" B) j" ^" b- {/ u8 t: |
        end  y3 H: l: }! ?8 v3 z- J
        v = -v;% flip the sign for second or third quadrant7 z/ p5 v5 d- C( `7 Y2 v
        return$ d, n8 z2 o8 N6 Z0 y
    end
    3 a+ r/ H" H& v& m. y% Initialization of tables of constants used by CORDIC4 _9 ]4 w& }. ]! P6 c! [7 L# x
    % need a table of arctangents of negative powers of two, in radians:* B+ x( ^. u# p+ |
    % angles = atan(2.^-(0:27));/ h7 y* H" A+ m7 R- U# `5 P# v- |# J
    angles =  [  ...
    ) Q! C/ c/ }& P8 M( |* D    0.78539816339745   0.46364760900081   0.24497866312686   0.12435499454676 ...
    ' }. }% v& h; @    0.06241880999596   0.03123983343027   0.01562372862048   0.00781234106010 ...
    7 t! k3 E; v2 ~4 P6 r3 N& E    0.00390623013197   0.00195312251648   0.00097656218956   0.00048828121119 ...
    - h3 i+ Q# G1 v& i; Q    0.00024414062015   0.00012207031189   0.00006103515617   0.00003051757812 ...
    ! J! _0 e, a& c& Y    0.00001525878906   0.00000762939453   0.00000381469727   0.00000190734863 ...
    $ k( s/ h4 i5 s5 @9 }( q    0.00000095367432   0.00000047683716   0.00000023841858   0.00000011920929 ..., g. e. j6 u) v6 L7 U
        0.00000005960464   0.00000002980232   0.00000001490116   0.00000000745058 ];
    - ?# E2 @1 M0 s& X% and a table of products of reciprocal lengths of vectors [1, 2^-j]:% E7 o/ O# d4 T
    Kvalues = [ ...% z: |+ F2 q6 \) s
        0.70710678118655   0.63245553203368   0.61357199107790   0.60883391251775 ...
    5 ~8 I6 U. {2 M( @    0.60764825625617   0.60735177014130   0.60727764409353   0.60725911229889 ...! A( s. o' w( \% c8 f3 }
        0.60725447933256   0.60725332108988   0.60725303152913   0.60725295913894 ...' ?9 k9 }# s' r, q+ }+ U
        0.60725294104140   0.60725293651701   0.60725293538591   0.60725293510314 ...9 C2 V& L5 `5 n7 {6 K  C- c
        0.60725293503245   0.60725293501477   0.60725293501035   0.60725293500925 ...1 h& y9 j3 e1 O$ G, q. A7 H9 t
        0.60725293500897   0.60725293500890   0.60725293500889   0.60725293500888 ];
    * \4 c' U: r6 l! s+ i' QKn = Kvalues(min(n, length(Kvalues)));
    3 H0 a- ?+ ^' @ + Q, g, c; x3 E$ a0 D( y
    % Initialize loop variables:
    2 h3 J/ u4 a1 J' K% Bv = [1;0]; % start with 2-vector cosine and sine of zero: q& p4 w! d7 a- e
    poweroftwo = 1; . n; \1 e; v- q- O7 `
    % Iterations
    4 u1 N- e. \/ P% b% cfor j = 1:n;  Z+ |" X' o1 n  ?0 R+ D
        if beta < 0
    " X! z. ]0 ~, x$ Y: z9 B        sigma = -1;7 ]1 {3 t7 g3 ?
        else
    1 x$ w% ]' n) G        sigma = 1;
    # O0 {) S6 \. p9 L* q    end
    , s0 ^% a9 U% k, |* h    % update the angle from table, or eventually by just dividing by two  [8 g0 V" x) [3 @# V0 G- h# x$ @
        if j <= length(angles)5 h  L: A& l9 z1 _4 f
            angle = angles(j);
    . e9 ^1 E, O' P( A4 K9 J+ l    else3 q6 O7 i9 S+ C$ }/ Z/ E4 Y/ W  J
            angle = angle/2;
    4 \/ q3 q' k' j! L/ P! F9 r" n8 g    end
    : P& Y' w% c1 G7 C+ w6 V    factor = sigma * poweroftwo;; ]0 b9 D2 `" Y' J
        R = [1, -factor; factor, 1];
    " p8 Y' h  j8 W- e1 o4 t  r7 n    v = R * v; % 2-by-2 mtrix multiply
    , W; N/ S, A; T    beta = beta - sigma * angle; % update the remaining angle
      U& d5 |- Z* ^3 |$ e/ o+ E    poweroftwo = poweroftwo / 2;
    3 o' ^& A+ F' O1 Zend
    2 A6 f0 m6 D- _7 j1 C# c: ]7 \  p% Adjust length of output vector to be [cos(beta), sin(beta)]:$ R# g* r! H' V, t, @' N; Z8 l
    v = v * Kn;
    ) z% G5 @. @* J  o/ Zreturn6 q4 v) q$ v/ Z: [
    , r$ ?  m4 K& E' G5 b/ m6 W
    使用20位寄存器,仿真波形如下:) g* C, ^& b, y5 t: [- }
    仿真波形
    7 i  H" ~, C) c5 z

    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 , {7 Y3 `& g9 z8 C3 k9 z
    这是什么算法?第一次听说
    8 E4 P9 y' A$ m4 D" a/ o, w! ?5 @; T
    这个,就是那个。感兴趣的话你还是自己搜搜吧。
    我正在用金山快盘。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 % x6 _& g' k- A6 d9 o4 A/ P
    我表示很给力
    % ]5 Q$ y4 {  `4 P) e; O. H
    给力就好。呵呵
    我正在用金山快盘。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-4-17 17:18
  • 签到天数: 3591 天

    [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-20 08:59 , Processed in 0.526952 second(s), 105 queries .

    回顶部