QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 9658|回复: 2
打印 上一主题 下一主题

极限测试之Matlab与Forcal的递归函数调用效率

[复制链接]
字体大小: 正常 放大
forcal 实名认证       

45

主题

3

听众

282

积分

升级  91%

  • TA的每日心情
    难过
    2012-8-27 18:22
  • 签到天数: 1 天

    [LV.1]初来乍到

    跳转到指定楼层
    1#
    发表于 2011-7-31 10:08 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta
    以Fibonacci递归程序为例进行比较。/ |1 W( G% b# ^, l# a: p

    2 W# c* j' n) N% [' [Matlab 2009a的Fibonacci函数定义:
    1. function k=fib(n)
      & P1 s\" E! `' U1 l
    2. if n == 0
      9 q8 U) b6 X6 k  r# {% `$ R0 l) w
    3.   k=0;
      3 I' C' q  n% o7 ~1 c
    4.   return;
      + d: D! t  ~9 u4 |$ ?5 j8 i- y/ j
    5. else if n == 1, {( b# a* V& |4 @5 g
    6.   k=1;2 H, L& u: c. W% J6 K
    7.   return;
      6 h3 n6 u( Q: Z' m3 U; I, T
    8. else& H* ]\" _# p- ?5 `
    9.   k=fib(n - 1) + fib(n - 2);7 I* z% Y3 c/ w2 B; Y; n  X. |# o& V, \
    10.   return;5 {1 D6 Q, w, C/ r& o
    11. end
      , K, _0 J/ a/ \! ?) j- b( n
    12. end
    复制代码
    运行结果:
    1. tic;6 {6 Y* X( H: x; l& U! T
    2. fib(30)! F1 R4 N8 [: V9 b8 P
    3. toc
      ; t1 C- p' b: L\" @! ]) }6 y
    4. , ^1 \4 T7 l9 g7 U& Q9 h\" |: h
    5. ans =6 M. K\" o5 s; P2 D+ x
    6.       832040
      ! }! j* O6 V+ w3 c
    7. - _4 K\" B# d4 u8 g\" W, W
    8. Elapsed time is 26.315245 seconds.
    复制代码
    ===============$ d8 y' [6 \- O- Q

    5 U6 B4 R' X6 a* v1 P0 sForcal 9(OpenFC演示)的Fibonacci函数及代码:
    1. SetRealStackMax(1000);
      : w1 ]% l: F; G8 M7 d
    2. F(n)= which{
      5 Y1 m3 P9 O4 {( K/ B& C/ U
    3.     n == 0,
      . f# x1 g4 M\" W
    4.         return(0),
      * d1 o) `& F' ~
    5.     n == 1,3 a2 f3 E9 y9 F' Y
    6.         return(1),# @- r. I* O7 K
    7.     return [F(n - 1) + F(n - 2)]; W( k# R' h  j3 c% a4 y8 i
    8. };
      \" A, ^. z; K( q
    9. mvar:
      5 Q& B. O6 D* A. L- @
    10. t=sys::clock(),
      9 V% d1 z- [- k! h4 B, K  D, G. D- q
    11. F(30);
      \" G% ], \) g5 M# g; a
    12. [sys::clock()-t]/1000;
    复制代码
    结果:
    0 e, E% D! {) @4 R832040.
    * r- x' K" G# R) E0.391  秒# f; b8 `2 H4 m1 @. g4 l0 m" q# n' H
    4 ~$ V& y& D7 n3 X1 Y4 H
    二者效率相差数十倍。
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信

    0

    主题

    0

    听众

    3

    积分

    升级  60%

    该用户从未签到

    回复

    使用道具 举报

    alair005        
    头像被屏蔽

    0

    主题

    4

    听众

    782

    积分

    升级  45.5%

  • TA的每日心情

    2012-2-7 08:08
  • 签到天数: 5 天

    [LV.2]偶尔看看I

    提示: 作者被禁止或删除 内容自动屏蔽
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-4-16 22:33 , Processed in 0.295141 second(s), 68 queries .

    回顶部