QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 9663|回复: 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递归程序为例进行比较。
    : ?8 d3 W$ Q- f/ x5 o
    - p6 W4 h. N% l7 b$ Z* U; jMatlab 2009a的Fibonacci函数定义:
    1. function k=fib(n)3 U, f5 i- O! F$ t& \$ n6 ~; G
    2. if n == 0% N% Z& d' i; I5 X, }4 W' y
    3.   k=0;/ K5 T9 @: |1 K, D& V
    4.   return;
      2 s& C8 Z  L: w9 P$ L
    5. else if n == 1
      . O6 G2 }3 z' @; I6 L& R
    6.   k=1;% U\" e) @0 T% `( o
    7.   return;) j# ]5 b+ n' w, d
    8. else
      7 _  D9 v3 K! X- F5 @6 |
    9.   k=fib(n - 1) + fib(n - 2);0 Y4 s* i5 z, h* f5 X6 g3 W
    10.   return;# w2 R( g7 I7 J2 u5 f
    11. end
      5 s$ O% k6 N\" Y2 f\" p
    12. end
    复制代码
    运行结果:
    1. tic;# k0 v\" L  h! x! O% Z: L  w0 d
    2. fib(30)! g\" D3 f) V* U  l' N( y
    3. toc% c1 `6 G( U: Y7 ^
    4. . R9 i9 o* w$ M/ K! L% o
    5. ans =7 o, E$ z5 y& X' Q
    6.       832040; C' j5 ^: R9 j' n7 F
    7. ) T3 @& d# V, }1 E
    8. Elapsed time is 26.315245 seconds.
    复制代码
    ===============9 b' D1 K! _( T- E
    9 y8 N  C# _0 s) T( z" [' E- c9 s
    Forcal 9(OpenFC演示)的Fibonacci函数及代码:
    1. SetRealStackMax(1000);7 Y. I# {3 |/ W0 v' e
    2. F(n)= which{
      * H. I) g4 u. C2 `7 e; H
    3.     n == 0,7 [. F8 O( J0 ]7 [
    4.         return(0),
      + A  ]! @' y' O/ [1 S
    5.     n == 1,6 ]  R4 u7 h9 d9 V% g\" P
    6.         return(1),
      / e3 `8 i- \# j! P: J6 U\" C2 F
    7.     return [F(n - 1) + F(n - 2)]  n4 d- |. `& L- `0 N4 H: q
    8. };* h5 p: \& s; A3 S
    9. mvar:' a2 ?# }! x/ s7 T1 F) S
    10. t=sys::clock(),4 m- A& d$ u3 I9 L0 A4 T
    11. F(30);6 A; \9 n0 p' ~/ G) p* `% t
    12. [sys::clock()-t]/1000;
    复制代码
    结果:  E- O7 K( A6 z* Z/ H/ P
    832040.
    $ S% [2 k4 n7 Y- E" f0.391  秒
    * k8 h) B" F: a8 j  z/ z, h* {9 L; `0 ^3 C( e/ c& L/ V+ i9 H7 ?$ k
    二者效率相差数十倍。
    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-20 00:29 , Processed in 0.905231 second(s), 67 queries .

    回顶部