QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 8859|回复: 4
打印 上一主题 下一主题

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

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

45

主题

3

听众

282

积分

升级  91%

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

    [LV.1]初来乍到

    跳转到指定楼层
    1#
    发表于 2011-8-2 09:51 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta
    这里用一个不太常用的小例子说明一下。
    / V! w( ^* @5 b& v, u, x9 {0 R4 t+ p. i% B8 c
    matlab 2009a代码:
    1. clear all
      ! z6 t/ O( i0 ?. H
    2. tic9 h- E- Y- G\" h. x1 x0 c
    3. s=0;
      \" V) Y8 P( p4 q, G
    4. for k=1:1000
        @7 Y\" M- {: b! B# y: T
    5.   for i=1:1000
      , [# U$ h2 S8 @5 k, d6 i
    6.     a=linspace(2,2,1000);9 f3 G5 n! v, n6 ^' ~
    7.     s=s+a(i);; Z# q5 _$ C2 U6 j
    8.   end) v' }3 C! [- x6 n/ S! |5 i' m- f
    9. end8 B# z3 G+ V0 j  w6 H2 O1 f) X
    10. s
      ) `5 ]+ O1 u; ]' q
    11. toc$ t+ }0 i- u5 V$ |& j; [0 r, g

    12. 0 D8 T4 s/ T/ {6 u7 ]) `3 Z' G
    13. s =% i! U' ~5 I% g+ D& l
    14. + T0 c) z: q! ?* P+ T- \0 r3 M
    15.      2000000. h9 M2 P) U& @) A\" r4 D

    16. \" T& o1 Z/ Q6 c$ ^
    17. Elapsed time is 18.325900 seconds.
    复制代码
    程序运行时内存比较稳定。9 p- M% d. z! V" \. Z% z+ z) t

    / P' j. V7 G, I( }7 e. b3 ?--------% o1 |  g0 K' ]5 f$ h
    ) g2 t( R+ n6 T6 o9 ~
    Forcal代码:
    1. !using["math","sys"];' Q% a3 b4 z+ q1 R7 d; p
    2. mvar:
    3. * S6 D! ?3 e: g3 p! [
    4. main(:a)=( H. ?* p% x% q: V
    5. t0=clock(),
    6. % C- A0 l\\" |- z1 S' j& O* A6 w3 V
    7. s=0,+ g* D: |' l8 N2 {- n$ p
    8. k=0, while{k<1000,3 p# u2 X& o/ T7 R3 i' T& O
    9.   i=0, while{i<1000, a=linspace(2,2,1000), s=s+a.i, i++},  // 嗯,a.i 就是 a(i)6 `+ t- L2 c% z/ l! y: O6 u/ r7 s
    10.   k++* J/ d9 n, U6 F( ^& Z
    11. },6 `2 K8 @' t  i+ ~4 P& c& r
    12. s;\\" |7 B; z: o. h9 K\\" O7 f
    13. [clock()-t0]/1000;
    结果:
      D3 C3 x8 i5 ?$ B- }9 b2000000." d  o8 ^5 x& h7 G: ]+ x, D. K; M' E' I
    40.766 秒
    + G& z" Z+ T8 n1 o) z  g# q: y8 |0 |- D" w. Q( e
    程序运行时内存不稳定,时大时小。该程序导致Forcal垃圾收集器启动约10次,垃圾收集前内存消耗大,垃圾收集后内存小。; E* F3 m( f! L, t5 |
    因垃圾收集器多次启动,故耗时较长。
    9 X( u! t$ A3 W3 h6 c0 Z8 {
    * j7 Y" \  g* E+ f; t$ B5 T2 r------------
      z# G1 ?1 W3 W. ~( R+ j5 |4 e# h( f5 g+ E2 {* l
    以下将a=linspace(2,2,1000)放到了oo{  }函数中:
    1. !using["math","sys"];
    2. # t* S8 t0 K! I' [8 r
    3. mvar:, D, P$ ?7 Y6 l4 F5 S$ J% c2 @! w
    4. main(:a)=
    5. / S: D/ }\\" }. F1 C. J. ^. {0 H) i5 y
    6. t0=clock(),; q5 o/ a\\" V6 \+ X* o
    7. s=0,
    8. ) Z4 k( `# |# B0 V% p) o! x
    9. k=0, while{k<1000,
    10. 6 ?- K8 k\\" S3 L+ x
    11.   i=0, while{i<1000, oo{a=linspace(2,2,1000)}, s=s+a.i, i++},  // 嗯,a.i就是a(i)
    12. 1 L( ~) g( B# O
    13.   k++
    14. ) Y! S( P8 m' Y$ b; L+ W
    15. },/ u! a5 ~  t1 ]( r1 D  N
    16. s;% s\\" K: W' j1 B1 |1 t* E, z
    17. [clock()-t0]/1000;
    结果:
    1 O% ]5 B+ \$ R, H* B9 C2 Z  T& O2000000.
    8 k; z; @8 P0 o+ E  i4.609 秒
    6 Y7 ^& R) P2 v4 J) h: l1 z) c3 |6 e* B* ~( o- [& E
    可以发现,Forcal耗时大大减少了,远小于matlab耗时,这要归功于oo{ }函数。. d- {1 O+ I+ V5 ^" Z
    在Forcal中,函数oo{ }不仅提供了运算符重载功能,而且会自动高效地回收垃圾。通常,所有涉及到对象的代码都要放到函数oo{ }中。
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信

    36

    主题

    3

    听众

    1734

    积分

    升级  73.4%

  • 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
    - f$ F" b( E6 Q2 g  d' T太强大了 看不懂啊
    ! D! O' l- h; A3 u" D
    函数linspace(2,2,1000)放到循环里,每循环一次就会产生一个垃圾对象(一维数组),主要对比Matlab和Forcal如何处理垃圾对象和进行内存管理。
    回复

    使用道具 举报

    36

    主题

    3

    听众

    1734

    积分

    升级  73.4%

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

    [LV.8]以坛为家I

    群组2012第三期美赛培训

    forcal 发表于 2011-8-2 18:18 * F3 i. J- L# [" x# w* a. K
    函数linspace(2,2,1000)放到循环里,每循环一次就会产生一个垃圾对象(一维数组),主要对比Matlab和Forc ...

    * i+ `/ @0 [* B, [* _+ F' L恩 我在研究研究,谢谢了
    回复

    使用道具 举报

    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, 2026-4-20 07:25 , Processed in 0.456969 second(s), 74 queries .

    回顶部