QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 14358|回复: 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 编辑
    ( }# e+ Z5 E8 {3 H8 d7 J" _- v1 W9 q# f+ `' B* i( j- F
    不知道有木有人研究这个,比较偏向于硬件描述。
    8 p6 F4 c+ `& r+ q5 @3 T2 }3 b+ U) n今天先发一个sine cose函数的实现。  ~  x% s8 [/ \4 N* O
    有兴趣的可以看一下,m文件见附件。
    # I/ v- q% C2 t' ^1 ffunction v=f_cordic(beta,n)
    ' q3 q/ ^! z5 {8 P. n) ?4 vif beta < -pi/2 || beta > pi/2
    4 S2 Q9 u. K5 a5 i& ?    if beta < 00 N4 z  E  d4 m8 e; H* j
            v=f_cordic(beta + pi,n);
    # N. p4 m: R- J2 B    else
    " w: n! a( s# D2 X' ^/ ~. _        v=f_cordic(beta - pi,n);# r0 [( K. ]1 `- [& q- M- ^) V
        end2 W' B0 A$ n) Y! O  N9 O  P9 {! _
        v = -v;% flip the sign for second or third quadrant' p* z. W: @2 x3 o, I
        return
    ' B! J1 R  u% l3 d9 h& [* ?end7 [# N7 u  Y! C1 o& ]
    % Initialization of tables of constants used by CORDIC
    ) l9 G% p4 J! p& M, s2 y% need a table of arctangents of negative powers of two, in radians:
    * V2 a$ t- b4 Y9 O% angles = atan(2.^-(0:27));1 H% x0 w6 @/ y
    angles =  [  ...  W, a2 h" n3 h/ Y8 O, e7 ?
        0.78539816339745   0.46364760900081   0.24497866312686   0.12435499454676 ...4 O2 ~. W9 S9 [4 g$ w
        0.06241880999596   0.03123983343027   0.01562372862048   0.00781234106010 ...
    1 w& e! G8 n0 E1 I) P1 F1 s  D' a    0.00390623013197   0.00195312251648   0.00097656218956   0.00048828121119 ...& v* {: g. I" s/ R+ }9 r6 c
        0.00024414062015   0.00012207031189   0.00006103515617   0.00003051757812 ...0 H" P# l* \  \: `% M' m+ n# a
        0.00001525878906   0.00000762939453   0.00000381469727   0.00000190734863 ...! W( G+ a$ x4 z) u+ V6 p0 T
        0.00000095367432   0.00000047683716   0.00000023841858   0.00000011920929 ...6 o: s) l% o; }& Z4 o' e' ^
        0.00000005960464   0.00000002980232   0.00000001490116   0.00000000745058 ];" Z* U& o; n5 \: E& h2 S
    % and a table of products of reciprocal lengths of vectors [1, 2^-j]:
    9 g3 E2 o5 t( X4 `$ T9 ?Kvalues = [ ...
    : w  t) A* {2 K7 E" _- K5 B- f    0.70710678118655   0.63245553203368   0.61357199107790   0.60883391251775 .... j5 w) E  ^4 _( n6 \' H+ a3 N5 l8 o
        0.60764825625617   0.60735177014130   0.60727764409353   0.60725911229889 ...) `8 m1 y& l  ^4 H
        0.60725447933256   0.60725332108988   0.60725303152913   0.60725295913894 ...
    . Q' U' W! Q+ Q, k    0.60725294104140   0.60725293651701   0.60725293538591   0.60725293510314 ...
    & X6 n3 n9 ~, l& {0 |: ]    0.60725293503245   0.60725293501477   0.60725293501035   0.60725293500925 ...$ P! m$ I/ B4 ^  S% l& `  u
        0.60725293500897   0.60725293500890   0.60725293500889   0.60725293500888 ];
    ) h! M3 z5 ~- P- F# p3 cKn = Kvalues(min(n, length(Kvalues)));. A& Y9 V  H4 N

    * q  t2 |6 F: O% Initialize loop variables:8 ~* g$ f5 k4 l# z) G
    v = [1;0]; % start with 2-vector cosine and sine of zero
    / {1 Q! K5 d% T7 c( w  y$ B& l* npoweroftwo = 1; 2 K" \4 G/ E+ z+ Z
    % Iterations. W: H7 V  b3 X  I4 `. r
    for j = 1:n;
    % Q. T1 i" a8 }    if beta < 04 C& j" M( ]8 T1 l
            sigma = -1;
    ) O& K8 ?. O8 q+ |( g    else% @! ^4 P. t5 b$ R2 b' S% c# l
            sigma = 1;9 ?6 r3 S: O4 W% \
        end
    * I/ M8 D6 Y8 G/ M0 l3 U( I    % update the angle from table, or eventually by just dividing by two
    : E3 _% R! ~9 n. s$ ]    if j <= length(angles)+ J; n4 l; [7 b$ C
            angle = angles(j);
    9 U* L: b; ?9 j% h" s. K( ?3 T    else
    # a0 }3 b% G) p        angle = angle/2;1 k" T" O7 _, o; e- L
        end
    ( _1 ?7 N: n4 g1 b2 m6 A    factor = sigma * poweroftwo;, Z- {9 r1 F; U
        R = [1, -factor; factor, 1];; T! Y) ?2 ^  o
        v = R * v; % 2-by-2 mtrix multiply( Y0 K0 p2 q, K6 a* N) Y% C
        beta = beta - sigma * angle; % update the remaining angle# `" K6 \5 J. G
        poweroftwo = poweroftwo / 2;
    7 K" B5 _1 G) Lend% V) l" ^1 E  m) J& Y7 D4 G9 }
    % Adjust length of output vector to be [cos(beta), sin(beta)]:9 U# h5 f  h& w4 N9 z  S
    v = v * Kn;
    7 m1 a) S5 c  m) x7 Yreturn
    & d4 {8 n4 ^) s; A
    3 O8 s  `! _& @6 A0 N使用20位寄存器,仿真波形如下:8 }- q2 T8 u0 B/ z) C; Y: a
    仿真波形
    : X; P* l3 Z# n% ?+ `" c

    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
    ( N8 B+ C- q4 o- L6 n这是什么算法?第一次听说

    + o6 A3 ?$ ]* Z这个,就是那个。感兴趣的话你还是自己搜搜吧。
    我正在用金山快盘。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
    , Z" B' H2 C- h: H我表示很给力
    % S, _  N8 {. n# r, ?# j
    给力就好。呵呵
    我正在用金山快盘。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-7-28 16:31
  • 签到天数: 3577 天

    [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-4 09:06 , Processed in 1.236299 second(s), 108 queries .

    回顶部