QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 15057|回复: 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 编辑
    9 H5 B: P& S( \7 t6 z
    # k! N9 j+ L2 u9 t不知道有木有人研究这个,比较偏向于硬件描述。
    " _7 l: v1 l( C今天先发一个sine cose函数的实现。; [' E$ U# v1 H% }& L1 ?
    有兴趣的可以看一下,m文件见附件。/ q0 y* g% J% U! y) ^) Z
    function v=f_cordic(beta,n)
    5 P/ R) @4 ?' D9 xif beta < -pi/2 || beta > pi/26 E; P6 v  a3 o
        if beta < 0
    1 ^$ |; p- @2 p& S3 j3 ^. {        v=f_cordic(beta + pi,n);
    / t7 r3 o8 v+ f  h    else
    ( B/ I3 H- H9 F7 m6 F        v=f_cordic(beta - pi,n);) i* l3 J( P8 v2 b: u
        end! |+ t' _& {/ R
        v = -v;% flip the sign for second or third quadrant' j0 ~5 m% {, O0 Y
        return0 P( a. R, I# [- {- q; g$ a
    end1 X0 L' ^3 L+ q0 `7 z
    % Initialization of tables of constants used by CORDIC- H* V& x: t5 M& f+ I5 k+ I$ M
    % need a table of arctangents of negative powers of two, in radians:
    " e  I8 T, S0 M/ o6 Z% angles = atan(2.^-(0:27));, a' P9 R' J8 k' ~, F
    angles =  [  ...
      J4 F$ j5 }0 q3 c3 f+ e    0.78539816339745   0.46364760900081   0.24497866312686   0.12435499454676 ...! R: f1 |; R5 W; \! Q5 a# O
        0.06241880999596   0.03123983343027   0.01562372862048   0.00781234106010 ...* D: q2 u$ F2 w( B! R" M# C& u
        0.00390623013197   0.00195312251648   0.00097656218956   0.00048828121119 ...+ w) J! {3 W  w9 v% d% o
        0.00024414062015   0.00012207031189   0.00006103515617   0.00003051757812 ...
    2 s5 a4 M! z, z+ V$ ^/ O    0.00001525878906   0.00000762939453   0.00000381469727   0.00000190734863 ...
    3 O" T7 T+ d- ^' M% |* c3 _    0.00000095367432   0.00000047683716   0.00000023841858   0.00000011920929 ...
    % b& U5 w. I4 x# ?    0.00000005960464   0.00000002980232   0.00000001490116   0.00000000745058 ];8 ]9 j! k! i- Y4 ?/ O; q* A; n
    % and a table of products of reciprocal lengths of vectors [1, 2^-j]:
    % E- h" Q6 H: h" qKvalues = [ ...
    ! d7 D) L$ {+ L    0.70710678118655   0.63245553203368   0.61357199107790   0.60883391251775 ...* P8 w- U# M- W! r+ d! h- u
        0.60764825625617   0.60735177014130   0.60727764409353   0.60725911229889 ...2 x; m6 j: h$ F  a  a
        0.60725447933256   0.60725332108988   0.60725303152913   0.60725295913894 ...2 H9 z1 e% P: x$ K& j& e
        0.60725294104140   0.60725293651701   0.60725293538591   0.60725293510314 ..." A! b8 K; c' f
        0.60725293503245   0.60725293501477   0.60725293501035   0.60725293500925 ...
    , H, k/ \- Q+ s# P* s' r% ^    0.60725293500897   0.60725293500890   0.60725293500889   0.60725293500888 ];
    2 Q9 `/ O% c* G( {- k0 OKn = Kvalues(min(n, length(Kvalues)));
    $ z3 C: V. H) z- w$ v9 R2 B* p
    ) m. g) X6 N# i5 U% Initialize loop variables:& V( Y8 e: y; h/ e
    v = [1;0]; % start with 2-vector cosine and sine of zero3 O  o7 T5 k: N! @
    poweroftwo = 1; : I: s& x# E/ r+ H( c! l
    % Iterations% I0 b% _5 `- S9 X) c8 v
    for j = 1:n;4 a3 _7 O+ x9 Z2 I- e
        if beta < 0
    1 h' k  n/ F1 f& u+ `        sigma = -1;
    ) G! W9 h' G" x+ V; \! U9 u    else) z( Z- @! P" C' j9 ^9 L2 o0 k" n
            sigma = 1;. l  \( [  {( D9 e. \8 `1 [
        end; m. o* s. H* g* {+ |
        % update the angle from table, or eventually by just dividing by two
    6 J. h2 F& q1 t/ x2 H* }- P# u# M/ C    if j <= length(angles)6 `4 d5 |4 W4 n6 @. J) x
            angle = angles(j);
    ' s6 X) N) D: g1 S- \# ~6 J    else4 C4 \' h6 Y. h% E2 @9 W' E7 u
            angle = angle/2;. U2 R* j+ q, S5 R* f
        end
    + N- P# b: m5 v) J) A    factor = sigma * poweroftwo;
    8 T/ r, K* Q9 i+ Z    R = [1, -factor; factor, 1];7 D2 @. f* {2 [+ O
        v = R * v; % 2-by-2 mtrix multiply
    ) r: a( o2 x* e6 b/ f; z1 P    beta = beta - sigma * angle; % update the remaining angle: v& D7 N+ d1 g# f5 r, {  p
        poweroftwo = poweroftwo / 2;3 P- R5 \5 {0 a$ `; `
    end
    0 h! g. `( V( w  A4 X% Adjust length of output vector to be [cos(beta), sin(beta)]:$ q- k/ J! Z% K1 d$ ?& A
    v = v * Kn;
    $ Y8 i8 `3 e6 z4 N  F4 xreturn) A2 s' R2 C7 y( @- P+ v

      G) q: ^5 Q& I) J使用20位寄存器,仿真波形如下:
    # w- R3 C8 l, W& p5 ^& `9 H 仿真波形 ' y8 I+ ~! I; x* O6 q

    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 r, }3 }1 \$ M2 y这是什么算法?第一次听说
    ( @) B. w+ @) r. X4 `  k
    这个,就是那个。感兴趣的话你还是自己搜搜吧。
    我正在用金山快盘。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
    / e( S4 |) \" E% |% d我表示很给力

    9 ?3 ^, k5 P% d, W4 Y给力就好。呵呵
    我正在用金山快盘。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-5-21 15:46
  • 签到天数: 3604 天

    [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-5-25 06:08 , Processed in 0.479373 second(s), 109 queries .

    回顶部