QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 14395|回复: 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) R8 d9 x, y/ Z7 G+ d
    % w( B; v1 _6 B& D! u0 Q
    不知道有木有人研究这个,比较偏向于硬件描述。+ E( J& p" L" m7 v6 x
    今天先发一个sine cose函数的实现。& P4 {/ w% t  T( h, q, H: G0 o1 o
    有兴趣的可以看一下,m文件见附件。
    ) U5 ?7 K) f3 t, Tfunction v=f_cordic(beta,n)
    8 r1 b- H/ g1 }( I0 B! Xif beta < -pi/2 || beta > pi/2
    " V; t$ J- H9 S2 e3 K4 k  o; B    if beta < 0
    : S$ u; a0 h  B8 w9 o' j2 u, }! N* w        v=f_cordic(beta + pi,n);: @7 Q4 x# F4 h6 W& P8 ~% B/ ]% H
        else
    4 L% T3 J9 d$ y1 P2 x2 y        v=f_cordic(beta - pi,n);
    $ f0 x+ s( {5 N' v' M5 [0 h    end& B! X! Z4 I- |, p& A9 ]: o- \
        v = -v;% flip the sign for second or third quadrant* @4 b7 c8 t/ r$ r. p8 n
        return$ U% `' A$ o* Y# g/ Q$ k
    end  N$ E/ ^6 |: c9 X$ p6 o( ]1 {
    % Initialization of tables of constants used by CORDIC
    ! D3 R1 }# Z; Z+ b  I! L% need a table of arctangents of negative powers of two, in radians:
    1 {8 C, ^  n& ^; l. [% angles = atan(2.^-(0:27));
    # i& ^! p( U5 b7 P6 {0 q1 k* ?angles =  [  ..." B' ^- V. _5 w. ^$ M
        0.78539816339745   0.46364760900081   0.24497866312686   0.12435499454676 ...# y/ ]6 j7 S1 x9 S+ b' }
        0.06241880999596   0.03123983343027   0.01562372862048   0.00781234106010 ...% p$ `% s- v1 _" ?$ y
        0.00390623013197   0.00195312251648   0.00097656218956   0.00048828121119 ...
    " R" F$ E+ ]/ I" K6 X9 w8 ]    0.00024414062015   0.00012207031189   0.00006103515617   0.00003051757812 ...9 N7 |% S! ~% z- Y
        0.00001525878906   0.00000762939453   0.00000381469727   0.00000190734863 ...* D2 z) l- R1 S# D, g% C4 ]
        0.00000095367432   0.00000047683716   0.00000023841858   0.00000011920929 ...9 b* a4 P6 U) }8 b! b. c9 A
        0.00000005960464   0.00000002980232   0.00000001490116   0.00000000745058 ];
    5 S$ a9 H6 Y) @% l) S% and a table of products of reciprocal lengths of vectors [1, 2^-j]:
    ( F1 X' p* ^. U) b4 m; a  P  x9 qKvalues = [ ...
    . D2 h( h. _* [& f: c1 [; P  V    0.70710678118655   0.63245553203368   0.61357199107790   0.60883391251775 ...
    9 |9 h6 S: ^1 [    0.60764825625617   0.60735177014130   0.60727764409353   0.60725911229889 ...
    # j. j; Y' O4 ]1 d$ O5 E    0.60725447933256   0.60725332108988   0.60725303152913   0.60725295913894 ...
    ) x& I0 P3 E) t! B  w' D/ r) s    0.60725294104140   0.60725293651701   0.60725293538591   0.60725293510314 ...
    $ H( i% G; \. S/ K    0.60725293503245   0.60725293501477   0.60725293501035   0.60725293500925 ...
    , \/ V) x* A5 Q9 \: c3 z4 O    0.60725293500897   0.60725293500890   0.60725293500889   0.60725293500888 ];
    ' L* a# f0 {$ z3 \8 P1 |- n' QKn = Kvalues(min(n, length(Kvalues)));! t: E. ?; p" b- q: C' T2 ^

    * H: T! f  X9 a& J% Initialize loop variables:
    $ B# l/ ]9 Z8 Xv = [1;0]; % start with 2-vector cosine and sine of zero6 x1 n( Z, @5 m3 A
    poweroftwo = 1; ) q2 g/ [' w6 S7 O1 [7 L
    % Iterations
    4 q* @  _; K2 M! Lfor j = 1:n;
    # J8 O, ?- b% w5 U7 ], @  k; g    if beta < 0  A( |7 \. ?2 E% m3 `  s
            sigma = -1;5 C& {7 B3 ]! T" X1 Z
        else
    8 M" \, l7 o% s% Y( n6 t        sigma = 1;# x0 S  t3 O& O, b$ ?9 P
        end
    6 s7 t  Y) w. t, q    % update the angle from table, or eventually by just dividing by two. p3 e8 u7 a; @* M3 ^1 m1 c
        if j <= length(angles)- I1 N8 d5 C' d) q
            angle = angles(j);$ d" U4 q7 m& `! w1 p
        else) W. c( E+ ^* I0 D; \7 w. A: @
            angle = angle/2;
    - b" b6 @8 n$ Z- M0 o4 _6 j5 O    end. U/ J# {# |# w9 t. `& P
        factor = sigma * poweroftwo;
    6 c& Z# C* Y7 E0 V    R = [1, -factor; factor, 1];
    1 I( X* t5 b* V& j) q" U4 |# S5 [8 v! W    v = R * v; % 2-by-2 mtrix multiply
    - g) B. \4 e$ d" k    beta = beta - sigma * angle; % update the remaining angle( @  V) a5 E2 J5 o, e2 l& U+ W, z
        poweroftwo = poweroftwo / 2;
    4 |. q; z! n' ]4 x  B( N, `end* |6 M: F* g, A# l9 V; V5 f
    % Adjust length of output vector to be [cos(beta), sin(beta)]:
    6 X: h3 X% |( c% R& G/ W9 jv = v * Kn;1 X2 O8 E' y( e* i
    return
    & I( {/ e3 q; y2 q; D2 _
      {; f$ `' r. g9 D9 |- B5 N  X使用20位寄存器,仿真波形如下:
    9 E) R4 b9 I) y8 h 仿真波形 2 l; I/ ]( |% a$ N0 b& |8 j) H. s, H

    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
    $ _$ I3 F! l, V7 c: p这是什么算法?第一次听说

    - V* x: n2 i, H这个,就是那个。感兴趣的话你还是自己搜搜吧。
    我正在用金山快盘。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
    # n1 {8 z& e2 M/ b0 U1 ~  x9 I1 a我表示很给力
    1 V: I+ J( K) E8 W$ _/ o2 t1 e
    给力就好。呵呵
    我正在用金山快盘。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-8-12 15:47
  • 签到天数: 3578 天

    [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-8-14 01:23 , Processed in 0.988833 second(s), 105 queries .

    回顶部