QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 8676|回复: 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
    这里用一个不太常用的小例子说明一下。( m5 u, D% s& U. r' j5 K

    4 p% m3 _7 m/ H0 f; Q& umatlab 2009a代码:
    1. clear all
      ! I# p1 c+ s9 T# T
    2. tic# W* g- @( @, _! F
    3. s=0;; l- {1 T$ z. C\" b
    4. for k=1:10008 n% Q4 V. b0 F9 t
    5.   for i=1:1000
      \" O& S- k4 s6 Q0 i- V
    6.     a=linspace(2,2,1000);
      - U- S. G1 X5 n
    7.     s=s+a(i);
      , S$ t! q% |* _3 d) t
    8.   end
      2 D0 H6 L+ j2 w\" C4 b2 k
    9. end- _8 X4 o6 Z0 Z) H8 y3 Q& C1 Y1 \( p# `
    10. s+ E8 F$ b5 H! _& w% _
    11. toc
      2 a, l* I& Y0 z) S$ U
    12. + C# x% I0 M9 g/ X- o
    13. s =& I1 R# {) Y& U* z\" F, e& E( l8 u
    14. ) k; D2 X8 w1 Y! F
    15.      2000000
      # s8 T$ N1 W, K0 V. S  I: e
    16. : p* x% O1 _( N) }
    17. Elapsed time is 18.325900 seconds.
    复制代码
    程序运行时内存比较稳定。" a$ l$ y. z6 J$ m

    ' ]) d" b$ _  i' m1 Z2 D0 k--------
    ) O. l- @5 \3 ?$ O! w: r* D6 S2 G- `* K7 n. @8 e
    Forcal代码:
    1. !using["math","sys"];
    2. : b; X5 s7 x( Z' q2 y7 N* {
    3. mvar:
    4. ; |  a& ~# n2 N% g\\" }; p
    5. main(:a)=
    6. - U( j6 ]4 \& E8 i/ N- i7 g2 {5 M
    7. t0=clock(),. T, X* p) N7 ~) _3 O
    8. s=0,
    9. : X/ B3 y( }' i7 D* o# W0 T
    10. k=0, while{k<1000,) C* t; y/ @! F+ r0 r, }( M
    11.   i=0, while{i<1000, a=linspace(2,2,1000), s=s+a.i, i++},  // 嗯,a.i 就是 a(i)
    12. 8 J\\" l\\" |+ ]' g4 k. b
    13.   k++
    14. : u, u# z, e/ h9 a6 l+ J: M
    15. },
    16. 0 ?4 T; ~3 N6 L
    17. s;2 S7 V# g' t( Q4 M. b9 V
    18. [clock()-t0]/1000;
    结果:3 N+ h/ l5 q6 O
    2000000.2 B3 I- ~4 C  K/ B- ~
    40.766 秒" X6 @. t* S3 m$ y2 f, Q
    " {8 i& x- s/ r( T! f
    程序运行时内存不稳定,时大时小。该程序导致Forcal垃圾收集器启动约10次,垃圾收集前内存消耗大,垃圾收集后内存小。' q/ Y4 O0 u- K; `/ G! g. b
    因垃圾收集器多次启动,故耗时较长。5 }4 F* l  o" h% S& O- u

    , d% P2 F6 d$ F, c7 \- a7 C------------
    7 D  D  `) u5 n* j; j$ R0 O8 b9 v- v) N/ E. m6 l3 i/ v
    以下将a=linspace(2,2,1000)放到了oo{  }函数中:
    1. !using["math","sys"];
    2. $ K9 P  W% J5 B
    3. mvar:
    4. 4 ]0 H1 w4 u1 t* {  X2 n7 g
    5. main(:a)=
    6. % ^; H- G$ H. I( Z5 G/ {- o% G7 R
    7. t0=clock(),4 G# o4 E0 {5 P
    8. s=0,' g) W* s' q/ q) N+ C: Y' S: T
    9. k=0, while{k<1000,# r: O, i% x! ?4 C+ e
    10.   i=0, while{i<1000, oo{a=linspace(2,2,1000)}, s=s+a.i, i++},  // 嗯,a.i就是a(i)  o$ @6 ^# Y5 U4 \
    11.   k++) i- m+ h( c4 s$ N
    12. },
    13. ' p: E( D1 u5 \& }
    14. s;4 |* J0 }% S7 P  u, V
    15. [clock()-t0]/1000;
    结果:! J0 O7 E. ~* v2 o) {
    2000000.+ ^2 t2 l) P" `& b; u3 C: [- N( v
    4.609 秒& N- `3 K+ N- N1 f
      ?  D  a5 v6 s2 {8 p% J
    可以发现,Forcal耗时大大减少了,远小于matlab耗时,这要归功于oo{ }函数。" ]: X) q! B; w4 X/ _5 |. ~
    在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
    " J) _, ?( D& I8 r& Z1 \太强大了 看不懂啊
    3 a& p$ @3 R6 ?. f6 A9 L. Q. g& c
    函数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
    - V# Y' y% F5 t7 g" v% X7 N3 Y函数linspace(2,2,1000)放到循环里,每循环一次就会产生一个垃圾对象(一维数组),主要对比Matlab和Forc ...

    , }! V3 O0 [3 K; \恩 我在研究研究,谢谢了
    回复

    使用道具 举报

    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, 2025-11-16 04:14 , Processed in 3.473417 second(s), 73 queries .

    回顶部