QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 9726|回复: 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递归程序为例进行比较。
    $ ?% `5 e2 W& t+ E/ v$ T$ ]3 ]/ m1 E  W# a, ]
    Matlab 2009a的Fibonacci函数定义:
    1. function k=fib(n)
      - H1 h: e+ p- w- Z0 \
    2. if n == 0
      : I! s7 Z\" X5 ^. n  y9 K% f
    3.   k=0;
      : f7 {7 V* ^8 p1 B, a# c$ u) `. I
    4.   return;
      ) U6 u4 x6 S( n' m8 \1 l
    5. else if n == 1. @3 Y5 M- m* c; \! {
    6.   k=1;
      \" v- I7 i- G4 D' \& `( b
    7.   return;
      9 `6 P9 y% Z\" g! B! g& j/ ^) U
    8. else$ c3 `1 [+ o1 t( d4 [- n  \
    9.   k=fib(n - 1) + fib(n - 2);- E$ `  X6 M8 [( \$ w$ h
    10.   return;
      7 L. m# v5 M, t6 E  U2 K, A
    11. end
      , w' U. h; o9 [; F
    12. end
    复制代码
    运行结果:
    1. tic;# s  d! O2 Z# N7 c+ W6 m2 Z7 B7 t7 N
    2. fib(30)
      . W% F7 b$ k  C# V, x
    3. toc, V1 a5 s4 P& l: F% `6 B- a
    4. & c- h# y; Y$ r4 _/ B\" U8 z
    5. ans =
      $ ?4 ?! C2 y\" R/ f8 X
    6.       832040
      8 E; @& t) l6 y; U+ }1 O
    7. 5 t9 k* W% ~; L0 e; C
    8. Elapsed time is 26.315245 seconds.
    复制代码
    ===============6 Z/ X: ]; w" q- p

    3 q2 q3 A2 j/ PForcal 9(OpenFC演示)的Fibonacci函数及代码:
    1. SetRealStackMax(1000);
      / G\" L) _' o6 `! i
    2. F(n)= which{
      9 @\" Q0 u0 e$ J% }6 j3 E
    3.     n == 0,
      / a, F- @8 \+ o0 a5 }& K. l9 E% o) ~
    4.         return(0),
      , Z$ r/ q0 S$ a\" K3 w+ x  U
    5.     n == 1,
      4 `  w! Z9 ]# u$ u# Q7 J4 @
    6.         return(1),
        |) ~3 t3 @/ [. l
    7.     return [F(n - 1) + F(n - 2)]* U( U0 D; s; g8 P- J9 d
    8. };
        x) W' ^  `2 e3 L
    9. mvar:6 `\" u$ o8 J0 `1 ?2 O0 P
    10. t=sys::clock(),
      # F: o1 a* d; G# L. J0 w* V+ g
    11. F(30);
      - }3 k, ]3 ?& P# [3 J9 F2 W6 T
    12. [sys::clock()-t]/1000;
    复制代码
    结果:
    % R9 R9 }5 F8 O; m; k7 _2 ]832040.& G7 A/ u2 P3 X# j7 x' t+ L
    0.391  秒9 y; ]; B& I* z* e
    5 E! \7 R, s' S: D: d) }0 u# S
    二者效率相差数十倍。
    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-6-2 01:27 , Processed in 0.412763 second(s), 68 queries .

    回顶部