QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 9733|回复: 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递归程序为例进行比较。* m  A0 {! V# T9 J7 H

    ( Y! e; h  S4 e) X+ ZMatlab 2009a的Fibonacci函数定义:
    1. function k=fib(n)
      , G\" P\" \: ]& g* Y  X$ l4 A( Y
    2. if n == 05 R* d2 T- I/ F/ ~, Q/ u: a4 W* w  [, Q
    3.   k=0;
      $ m) A* \% ]6 z; N( U
    4.   return;
      ) N4 u, p* O+ x: @, b9 S  ?0 s
    5. else if n == 1
      2 X% U3 f) Z6 T, F$ l( s  s
    6.   k=1;9 ^- R  u$ Q5 I( t  _3 L
    7.   return;
      ) y$ [) n/ _9 Z8 |$ M% \5 _
    8. else
      6 F. N0 C; _9 v6 U% E
    9.   k=fib(n - 1) + fib(n - 2);
      + f$ X: P/ x# t- ^
    10.   return;7 S; W2 S# \2 A! D
    11. end9 n5 c& |7 W$ C2 ^
    12. end
    复制代码
    运行结果:
    1. tic;; A\" Z- z; `. J' K
    2. fib(30)( z. ~( \* O+ q7 |5 C. q
    3. toc) i/ A6 ^, z+ e4 `5 g) ^% {: n

    4. , c! e4 U: a3 l) H
    5. ans =
      4 r& D5 C2 P9 j4 |* P( Q# h# a
    6.       832040
      7 n4 s9 _+ [# V0 `: y- L

    7. % m; u0 o1 Q! e8 f  j* l+ ~/ @
    8. Elapsed time is 26.315245 seconds.
    复制代码
    ===============) t. G4 k6 ]* j4 z

    ; j& G: o$ K  j' u" T. o- lForcal 9(OpenFC演示)的Fibonacci函数及代码:
    1. SetRealStackMax(1000);' P' C! t( x* n3 M) V! y
    2. F(n)= which{0 K; K6 w\" p. A: r
    3.     n == 0,( H; j1 v- a! H+ H& \
    4.         return(0),
      % r! H' o$ ~+ \6 I$ x\" @$ ~9 z
    5.     n == 1,: X% u2 }& L2 h- S. X; E
    6.         return(1),
      ( l* \& W! D( m3 `0 f; E3 q
    7.     return [F(n - 1) + F(n - 2)]/ v& f% ?# ~6 S) B
    8. };
      , K- r' T0 a8 ~7 ?5 v
    9. mvar:
      1 t/ ?+ F2 d' K+ P) s
    10. t=sys::clock(),
      - Z) @\" W1 {% y8 |
    11. F(30);9 `) e7 F& R7 K
    12. [sys::clock()-t]/1000;
    复制代码
    结果:
    8 F. z+ P# q: i! b832040.
    / C, Y& D# G+ G4 F0.391  秒$ V# ]! M6 P% q( {( Y
    7 T0 T6 n* G6 s8 U/ A
    二者效率相差数十倍。
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    alair005        
    头像被屏蔽

    0

    主题

    4

    听众

    782

    积分

    升级  45.5%

  • TA的每日心情

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

    [LV.2]偶尔看看I

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

    使用道具 举报

    0

    主题

    0

    听众

    3

    积分

    升级  60%

    该用户从未签到

    回复

    使用道具 举报

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

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

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

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

    蒙公网安备 15010502000194号

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

    GMT+8, 2026-6-2 06:48 , Processed in 0.487316 second(s), 69 queries .

    回顶部