QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 9481|回复: 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 F2 S7 F; t# L5 ?, {
    * c6 ]3 n! C, w5 ~
    Matlab 2009a的Fibonacci函数定义:
    1. function k=fib(n)' U; B% v* C. Z* m/ ]9 |6 z
    2. if n == 03 \* q' r9 f$ C  u
    3.   k=0;1 x/ w' k3 @7 `\" u8 c- Z
    4.   return;\" @7 @, @$ }7 `8 h* L
    5. else if n == 1
      + {! R& `$ r- N$ s
    6.   k=1;
      0 o& U9 F; m+ L, m( ]  y% @
    7.   return;
        Z- @, R, Y\" x, k! N1 w7 g
    8. else, v\" F9 t: {3 v6 B. J4 n
    9.   k=fib(n - 1) + fib(n - 2);
      9 J# V: g& T- P7 M* F5 C
    10.   return;- }, W1 @6 f3 N) c1 U
    11. end
      # G( U# n# @5 ^1 B& I0 @
    12. end
    复制代码
    运行结果:
    1. tic;\" ?. k- Z\" A* f7 o) h. V, Q1 F
    2. fib(30)
      # }$ k; G% I2 V4 I& b. b
    3. toc! N5 v' [\" _3 C\" o; G

    4. 4 I8 ~6 @3 g. l/ a
    5. ans =) y( K& y3 ?; |- i6 b
    6.       8320400 D5 K4 ^. B& d9 {# Z
    7. ! w% @# k3 k8 n2 s9 }6 F5 |$ [/ `; D
    8. Elapsed time is 26.315245 seconds.
    复制代码
    ===============. K: I$ P+ _% a' H. D$ n5 H/ w
    * V5 O0 O/ @$ a' ^
    Forcal 9(OpenFC演示)的Fibonacci函数及代码:
    1. SetRealStackMax(1000);/ {' q% T5 x. ?+ [
    2. F(n)= which{
      + |& z( d8 R2 e0 l: E
    3.     n == 0,
      + K% K* @0 }0 D0 J$ f8 E3 j
    4.         return(0),$ Z' {: ^5 z: @1 y9 g. r
    5.     n == 1,: ]4 q, c: k3 p
    6.         return(1),/ Z! _/ i. z/ b  Q) v3 |7 M* A\" a
    7.     return [F(n - 1) + F(n - 2)]
      , U7 T5 O1 A8 d* c1 `' a+ `
    8. };8 O4 m; r\" H3 s/ A5 v4 }' I+ i9 f. H
    9. mvar:7 Y1 A! a: ?5 E. Y
    10. t=sys::clock(),7 a! M! |2 n% d* h
    11. F(30);6 G) I7 j* J8 @# R8 \
    12. [sys::clock()-t]/1000;
    复制代码
    结果:
    4 n" d6 ?* V& _/ P832040.
    ' ]/ c) v2 M; m0.391  秒
    ( w7 {4 W# `( H$ a" `- o7 E& F# X! ?
    - {: P1 ?9 w: e' v% ?7 V/ t二者效率相差数十倍。
    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, 2025-11-15 22:15 , Processed in 0.881876 second(s), 68 queries .

    回顶部