请选择 进入手机版 | 继续访问电脑版

QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 7512|回复: 4

极限测试之Matlab与Forcal动态内存管理效率

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

45

主题

3

听众

282

积分

升级  91%

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

    [LV.1]初来乍到

    发表于 2011-8-2 09:51 |显示全部楼层
    |招呼Ta 关注Ta
    这里用一个不太常用的小例子说明一下。
    ) a/ q) V3 e$ M- \! o& I
    , _. s* f# G& O; L' d0 A: J  |+ jmatlab 2009a代码:
    1. clear all; N2 z3 j( X0 B& N6 D\" F! D7 U
    2. tic
      % [1 ]( e& l: z4 @: x  U
    3. s=0;8 v! X- T9 B0 ^% f. b  l
    4. for k=1:1000
      ! H2 @% ^' T3 t( J9 F4 E
    5.   for i=1:1000
      7 X! l. j# ?, |3 M5 `5 k* `+ V
    6.     a=linspace(2,2,1000);
        m; B\" W) y; X0 N; g8 Y, J7 b
    7.     s=s+a(i);
      7 _( e. v; c8 w6 y) v
    8.   end9 [7 ?, V$ h6 x& R: L/ U- `4 H
    9. end4 _# F9 d1 R3 I% a& m4 n0 L) j
    10. s
      - E  |5 P, I- s$ ]$ Y
    11. toc/ [# M+ D; }9 [9 c

    12. 1 \# w. Z8 w' z; K1 K* z
    13. s =4 c7 s9 e9 }  P$ g

    14. 0 y: Q, ~+ U6 s/ h+ D
    15.      20000005 z. Y- I6 g0 Q* B: f$ n

    16. ) O+ L3 H0 x\" e/ M# ^3 B' v
    17. Elapsed time is 18.325900 seconds.
    复制代码
    程序运行时内存比较稳定。* h5 @" T9 M3 ^$ X* D" G4 @
    ; t. h. W7 D& n# h. ~* l
    --------. }3 W. E7 R1 D
    ' {1 {! Y; H2 t' V7 [3 G
    Forcal代码:
    1. !using["math","sys"];; k  L- n5 {: J' j, r
    2. mvar:4 T7 M2 ~2 v\\" f8 M/ S8 {0 N+ i
    3. main(:a)=  T% s4 \1 u5 R5 K- ^  Z1 Q
    4. t0=clock(),
    5. 7 \4 A7 D  t1 L- u9 m5 h
    6. s=0,* M6 p' K$ e5 \2 }\\" M
    7. k=0, while{k<1000,- o- t6 s6 O\\" G* S, R- i9 n# o
    8.   i=0, while{i<1000, a=linspace(2,2,1000), s=s+a.i, i++},  // 嗯,a.i 就是 a(i)
    9. 6 I) }$ t! p# m9 O& K4 z% }
    10.   k++
    11. % K5 }5 h\\" e\\" u+ q+ `, k% Z' Y
    12. },
    13. . h( A5 x& Q: c$ T* `3 [! K0 Y
    14. s;
    15. / m1 u0 V& G: c& d6 ]2 U. K
    16. [clock()-t0]/1000;
    结果:. J* [1 @$ k5 L
    2000000.% x: M" m. C3 e9 K6 v! D( q" u% c+ x
    40.766 秒
    - J8 j" s8 F& u
    9 s" e9 c1 i8 r& I2 R程序运行时内存不稳定,时大时小。该程序导致Forcal垃圾收集器启动约10次,垃圾收集前内存消耗大,垃圾收集后内存小。
    & i7 t3 Z9 e9 a$ X2 o& M* q9 ]因垃圾收集器多次启动,故耗时较长。+ A( L" k* I4 u( R/ w6 ^

    ; _5 ^2 I) g9 v3 I4 |------------
    ( @! O0 N) b/ C. x* {' {
    8 J$ |6 J5 Z) j3 ^/ l% j以下将a=linspace(2,2,1000)放到了oo{  }函数中:
    1. !using["math","sys"];
    2. 4 o) |* s1 m. h. l. ]0 f+ A
    3. mvar:/ Z9 B; `% N/ V$ u8 c
    4. main(:a)=0 p7 I* W4 o* A/ P\\" ]
    5. t0=clock(),
    6.   t5 I% i3 ~0 n
    7. s=0,
    8. - ^  E% J' p' Q. V; B' j
    9. k=0, while{k<1000,
    10. # x, w$ t3 T4 U! V4 T1 z2 |
    11.   i=0, while{i<1000, oo{a=linspace(2,2,1000)}, s=s+a.i, i++},  // 嗯,a.i就是a(i)' o\\" b! o5 {6 I$ i$ G% A& m
    12.   k++
    13. . g: |1 h1 l- X$ o1 r+ i' H/ g( K
    14. },
    15. & y' K. Q; ]3 X  j& q
    16. s;
    17. ' H  m- H  G/ |) u3 g: o) ~
    18. [clock()-t0]/1000;
    结果:7 T! s$ p2 E7 c0 r8 v, f1 A
    2000000.  F: U, s$ n7 i' s( L7 P  }
    4.609 秒' S0 P2 X( A. c( w" L# j+ H4 ]
    7 t  }6 H( s- C5 w$ r0 p
    可以发现,Forcal耗时大大减少了,远小于matlab耗时,这要归功于oo{ }函数。; Z5 C# J7 L2 ?* J; H+ f
    在Forcal中,函数oo{ }不仅提供了运算符重载功能,而且会自动高效地回收垃圾。通常,所有涉及到对象的代码都要放到函数oo{ }中。
    zan

    36

    主题

    3

    听众

    1731

    积分

    升级  73.1%

  • TA的每日心情
    开心
    2015-7-2 19:17
  • 签到天数: 300 天

    [LV.8]以坛为家I

    群组2012第三期美赛培训

    回复

    使用道具 举报

    forcal 实名认证       

    45

    主题

    3

    听众

    282

    积分

    升级  91%

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

    [LV.1]初来乍到

    我就在你背后 发表于 2011-8-2 16:08
    # _: I+ E/ i5 m+ M+ d8 |) h/ X8 J太强大了 看不懂啊

    $ @" _2 M' N2 M; G. g7 H函数linspace(2,2,1000)放到循环里,每循环一次就会产生一个垃圾对象(一维数组),主要对比Matlab和Forcal如何处理垃圾对象和进行内存管理。
    回复

    使用道具 举报

    36

    主题

    3

    听众

    1731

    积分

    升级  73.1%

  • TA的每日心情
    开心
    2015-7-2 19:17
  • 签到天数: 300 天

    [LV.8]以坛为家I

    群组2012第三期美赛培训

    forcal 发表于 2011-8-2 18:18
    ' Y; }4 T  J! d: u& B8 S函数linspace(2,2,1000)放到循环里,每循环一次就会产生一个垃圾对象(一维数组),主要对比Matlab和Forc ...
    # Q7 r0 P! E; v( t  t! D6 W7 U& v! e
    恩 我在研究研究,谢谢了
    回复

    使用道具 举报

    sxjm567 实名认证       

    8

    主题

    7

    听众

    2174

    积分

    该用户从未签到

    新人进步奖

    群组数学建模

    群组我行我数

    群组数学趣味、游戏、IQ等

    群组09年国际数学建模群—鹰之队

    群组电子科大数学建模交流群

    回复

    使用道具 举报

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

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

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

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

    蒙公网安备 15010502000194号

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

    GMT+8, 2024-3-28 20:39 , Processed in 0.590539 second(s), 74 queries .

    回顶部