QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 14961|回复: 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 编辑 ; x7 O" v3 D. M- K" ^  v

    4 E3 a; i, n! j6 q不知道有木有人研究这个,比较偏向于硬件描述。
    ! W6 A" ]7 ~/ m  t& J$ J/ D今天先发一个sine cose函数的实现。
    ' b5 G0 T  A1 J0 ]! J" i有兴趣的可以看一下,m文件见附件。/ [/ A+ |" K% {- n7 t  A# b' j& j
    function v=f_cordic(beta,n)
    ! n- F  c$ u8 Y7 Jif beta < -pi/2 || beta > pi/2
    2 t$ z1 ]4 R. E( \: l; g% q$ w& A: G    if beta < 0
    - D4 X& h' `" v& a6 V: T        v=f_cordic(beta + pi,n);
    # R4 o' V! j9 w% X: y5 X4 }; N/ v( j9 u    else
    # x* k3 a9 W* f0 J, e, v        v=f_cordic(beta - pi,n);
    " d1 }& a( u0 k5 K( f    end5 P/ R' @& ~' l% P9 ]
        v = -v;% flip the sign for second or third quadrant
    9 `# }5 C* A3 J, r  [  o  ]7 @    return3 y6 m6 v, n: u! H
    end& U5 Z: f; f6 U' N$ ^+ G; h
    % Initialization of tables of constants used by CORDIC
    0 s; Y9 T" l) J: `0 D! L% need a table of arctangents of negative powers of two, in radians:
    0 R" ]. e0 C4 i. ~' i+ J1 x% angles = atan(2.^-(0:27));
    + b# n' F9 |. z9 bangles =  [  ...+ }4 ^4 U) F+ i5 Y& N2 t) n
        0.78539816339745   0.46364760900081   0.24497866312686   0.12435499454676 .... X+ U; H+ n' P+ j  q6 ]
        0.06241880999596   0.03123983343027   0.01562372862048   0.00781234106010 ...
    + u& I! L+ w( g5 y+ `; q    0.00390623013197   0.00195312251648   0.00097656218956   0.00048828121119 ...
    " L. O+ Q0 S; F+ c# j    0.00024414062015   0.00012207031189   0.00006103515617   0.00003051757812 ...: _7 L3 E6 l9 S0 T- O
        0.00001525878906   0.00000762939453   0.00000381469727   0.00000190734863 ...$ k/ R$ n  M5 a6 z8 v
        0.00000095367432   0.00000047683716   0.00000023841858   0.00000011920929 ...* J: p/ K) _& D# t0 D7 `" L4 b
        0.00000005960464   0.00000002980232   0.00000001490116   0.00000000745058 ];0 z. W+ @: }- l- y
    % and a table of products of reciprocal lengths of vectors [1, 2^-j]:" l# {1 ^% T. }2 |
    Kvalues = [ .../ [' d: C& U4 W# j6 |
        0.70710678118655   0.63245553203368   0.61357199107790   0.60883391251775 ..., Z& c0 Z% t# z; K1 ]# u- ~& J# C
        0.60764825625617   0.60735177014130   0.60727764409353   0.60725911229889 ...
    7 q) N& \9 y7 ]    0.60725447933256   0.60725332108988   0.60725303152913   0.60725295913894 ...$ G/ z+ M; H5 k
        0.60725294104140   0.60725293651701   0.60725293538591   0.60725293510314 ...
    ! j  v' N- O$ x9 D* p: G/ }    0.60725293503245   0.60725293501477   0.60725293501035   0.60725293500925 ...
    ' x) Z& d$ h$ L9 k1 S0 ?    0.60725293500897   0.60725293500890   0.60725293500889   0.60725293500888 ];
    / D& m& V1 N4 wKn = Kvalues(min(n, length(Kvalues)));' K; [2 x% h( e% w# C( K  J

    2 E' y$ X0 R9 l3 x% Initialize loop variables:- B3 V+ m) G' b. B  T( ~
    v = [1;0]; % start with 2-vector cosine and sine of zero/ H) r" m& R7 w; s: }9 A
    poweroftwo = 1;
    ( K5 ^1 B" ^7 y) P- W' I2 J0 s7 U% Iterations
    + o5 T- K! e; u% O# d5 \5 z. @" N$ Nfor j = 1:n;
    ; n' n  b! j0 g* T8 S    if beta < 0( R! b1 o, m1 L: l9 Q8 b0 u7 ^
            sigma = -1;: g+ i- ]7 z# r$ A1 V" b
        else
    . `9 U3 p, _  j0 \( Q2 S3 m        sigma = 1;/ V$ Y6 p0 @. [# Y1 w* e
        end
    6 I% E% W: B- x' g1 x1 [    % update the angle from table, or eventually by just dividing by two  n% h5 J3 W  L8 s7 q2 W4 z/ i
        if j <= length(angles)
    % ?8 d7 C& h7 p8 F, U        angle = angles(j);
    0 V5 X/ w6 T& z; n" h    else
    8 k% g# A9 [# B) q* D* C        angle = angle/2;
    1 l& g8 q1 z. m/ z1 C+ m  D    end
    " s% N3 k, f1 z& O/ Z( o( d    factor = sigma * poweroftwo;! Q/ n8 \* h& f% @' R
        R = [1, -factor; factor, 1];7 }' N! j* B2 Y! ~
        v = R * v; % 2-by-2 mtrix multiply
    6 I6 K) v/ |  }6 O    beta = beta - sigma * angle; % update the remaining angle
    " w0 A2 E  M* H    poweroftwo = poweroftwo / 2;/ \6 m! B4 W1 a: |* O5 w9 J! c
    end
    2 W$ D' c: z! p3 d, Q% G! M3 h1 R% Adjust length of output vector to be [cos(beta), sin(beta)]:6 V% I6 d& H& Y( i$ Y# ?  C
    v = v * Kn;
    % U) d1 N' o' h4 @2 Y- Preturn0 @" |7 h/ w9 g7 u

    * p4 |* U; m9 [/ o) _- P* Q( g  ?使用20位寄存器,仿真波形如下:" U4 H5 D0 R1 o: R! F, F  B" l
    仿真波形 # R( i7 Y4 @8 s7 J3 U; y

    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 # h6 l/ }/ X; u* G8 u* d8 _' p8 s) f
    这是什么算法?第一次听说
      o  k8 X& [# Y) p9 q5 X" i$ o- g
    这个,就是那个。感兴趣的话你还是自己搜搜吧。
    我正在用金山快盘。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
    7 ~* I% i) F9 F4 b9 l我表示很给力

    * `, _, F& s! M给力就好。呵呵
    我正在用金山快盘。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-15 02:11 , Processed in 0.513149 second(s), 106 queries .

    回顶部