QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 14833|回复: 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 编辑
    5 D, Y- j! k5 F/ C# Z/ K) X* L* {, Q( g1 r6 W; V- W
    不知道有木有人研究这个,比较偏向于硬件描述。
    ! q# w% m! A6 }& K6 T% G5 J2 G今天先发一个sine cose函数的实现。
    6 e$ f. ]# M3 `, a/ s7 U4 ~有兴趣的可以看一下,m文件见附件。) u. a: a9 L# Q0 ^/ `8 G" ^$ D
    function v=f_cordic(beta,n)
    ' K2 W% \4 `' F( g  h1 e/ r; R6 Fif beta < -pi/2 || beta > pi/2
    / _0 A3 a- g* W% `    if beta < 0- L- S% v; A: K% c
            v=f_cordic(beta + pi,n);/ L5 c4 Y' o2 X0 W2 b& V
        else$ R6 G3 |: A! l
            v=f_cordic(beta - pi,n);
    ; e: E4 R! v5 a    end. V0 M8 m, q! j) C1 O. H
        v = -v;% flip the sign for second or third quadrant* P; l, C* P/ E
        return' _) F- N: q: `- m# p9 j& z& P
    end
    / a# J' N& r  p" b9 @7 E: [% Initialization of tables of constants used by CORDIC
    5 D- p% }/ q: x% |/ w) x: j1 ^7 p4 C9 ]% need a table of arctangents of negative powers of two, in radians:
    ) l, t& w# x2 w' n- S% angles = atan(2.^-(0:27));5 r# d8 {, i, o2 P4 v% u& J
    angles =  [  ...& _" M  W  \1 i$ }: w3 h
        0.78539816339745   0.46364760900081   0.24497866312686   0.12435499454676 ...) i5 r9 V1 v: M1 w) d+ V
        0.06241880999596   0.03123983343027   0.01562372862048   0.00781234106010 ...
    ! S4 s6 _$ Q6 Z6 h7 C3 @    0.00390623013197   0.00195312251648   0.00097656218956   0.00048828121119 ...
    & V  H& ?) _5 Z9 V    0.00024414062015   0.00012207031189   0.00006103515617   0.00003051757812 ..." z. a: J$ T4 I2 _
        0.00001525878906   0.00000762939453   0.00000381469727   0.00000190734863 ...
    1 L  x' q* V% q' C4 N  D( J0 O    0.00000095367432   0.00000047683716   0.00000023841858   0.00000011920929 ...
    7 D) V; D% u" q5 [# x    0.00000005960464   0.00000002980232   0.00000001490116   0.00000000745058 ];" k. b/ x8 a9 P! S! p' \' ]
    % and a table of products of reciprocal lengths of vectors [1, 2^-j]:* s6 x5 T* C  _  g" x  B
    Kvalues = [ ...
    % g0 R# M# C) i: _) K. ~    0.70710678118655   0.63245553203368   0.61357199107790   0.60883391251775 ...& _& c  ~: V# f
        0.60764825625617   0.60735177014130   0.60727764409353   0.60725911229889 ...  R) \$ c+ @$ k* a" w4 }2 \
        0.60725447933256   0.60725332108988   0.60725303152913   0.60725295913894 ...
    8 w0 I; S& e* Z7 a3 [    0.60725294104140   0.60725293651701   0.60725293538591   0.60725293510314 ...6 T. s. u3 o* a" z3 h$ [  w9 l
        0.60725293503245   0.60725293501477   0.60725293501035   0.60725293500925 ...; U) F& {4 W& E& F
        0.60725293500897   0.60725293500890   0.60725293500889   0.60725293500888 ];1 X8 \  j1 `* V* N, Z
    Kn = Kvalues(min(n, length(Kvalues)));/ s& f' H' G( a# {1 o) R& Q
    2 h( t3 @4 N7 ~* d0 R/ F* E7 _# j: t
    % Initialize loop variables:
    & `  V3 M- z6 }& O2 iv = [1;0]; % start with 2-vector cosine and sine of zero! C+ S3 N# z' r8 g  R- ^! i' V
    poweroftwo = 1;
    ' |1 L5 m- s9 ~" Y8 e% Iterations. T- O- I7 b  ^- K3 r' t
    for j = 1:n;2 D  b; n( U( ?! f. u7 o2 d3 q
        if beta < 0
    + ~9 k* R, V1 M0 {" w        sigma = -1;
    - A/ M- q" v) ^. M    else! l- T3 c: l, m, Z6 t- C
            sigma = 1;
    8 C$ T+ ]# x& q" w" g9 p" ]    end
    ; K' ?2 {0 D6 y7 G  ]( {    % update the angle from table, or eventually by just dividing by two' p$ P8 t/ F3 |3 i
        if j <= length(angles)
    ' E; ~1 Q$ V6 J+ |- b' K        angle = angles(j);
    + I+ f1 w3 Q7 h+ C: z$ t    else
    ) j" ]1 E2 l& M        angle = angle/2;
    8 z" L/ d! S! Y; O/ T1 M4 J    end
    3 u1 O9 W; f3 v) z    factor = sigma * poweroftwo;5 i) H! M0 H/ P
        R = [1, -factor; factor, 1];) Z8 J0 a4 K8 u4 j* Q1 h% l3 @
        v = R * v; % 2-by-2 mtrix multiply" L% P$ g8 y, D& c$ J) P+ X8 T) ]
        beta = beta - sigma * angle; % update the remaining angle: S- a- v3 @0 p3 |8 L* L) l
        poweroftwo = poweroftwo / 2;! p; s$ V1 e1 g+ G
    end( K1 S! z7 A7 {5 e8 _, O7 i( |* ]
    % Adjust length of output vector to be [cos(beta), sin(beta)]:. O7 D+ W) l+ f' f* _* o
    v = v * Kn;
    # [& I' Q  p8 L5 xreturn9 h# U8 {) G% A3 Q. a
    9 |# ?3 v7 r! X% K7 p) L
    使用20位寄存器,仿真波形如下:& H. |: ]! Y+ I) O- |& Y. J1 X
    仿真波形
    ' `) }1 O2 R/ j1 w

    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
    6 }' W7 s* p# J5 p7 w这是什么算法?第一次听说

    2 K& O3 s, O% i这个,就是那个。感兴趣的话你还是自己搜搜吧。
    我正在用金山快盘。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 " A! v$ v/ ~8 C+ g/ I. b
    我表示很给力
    8 \- y% o9 g# c( B: f: ]
    给力就好。呵呵
    我正在用金山快盘。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, 2025-12-28 16:12 , Processed in 1.973729 second(s), 108 queries .

    回顶部