QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 8865|回复: 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
    这里用一个不太常用的小例子说明一下。
    2 U6 U* y. t1 U+ F& C3 U, j. U5 c( ^1 b0 \! S
    matlab 2009a代码:
    1. clear all8 T\" T8 _5 ]: Y. g' h+ @5 J1 |
    2. tic
      8 C4 t& F* E( D7 S4 V! v2 [
    3. s=0;7 Y\" z  @& u' \$ W' ?! M
    4. for k=1:1000
      , u! E! P* d: P9 {6 i
    5.   for i=1:1000
      2 ]# X( W# [1 _
    6.     a=linspace(2,2,1000);, b' J  w; {* {. D% k5 L' o) n
    7.     s=s+a(i);: Q+ p0 _& m6 g3 _; J5 P% i
    8.   end
      # s7 W4 j& ^2 c$ v; I: h
    9. end
        h8 [! F0 k8 f  r' c& j5 d7 B. V
    10. s
      ) W9 d3 S6 S+ l8 J! f
    11. toc
      \" t\" z0 B3 U1 G& d$ ]7 ]# Y
    12. , O, C. l1 d: y+ D1 U
    13. s =
      7 {7 ]+ m1 X4 c3 ~! ]
    14. : v1 ~) J4 P2 v+ u5 n
    15.      20000006 P\" X- L. H/ I\" O

    16. 0 ^\" p1 h* m; q2 q
    17. Elapsed time is 18.325900 seconds.
    复制代码
    程序运行时内存比较稳定。
    " X) W. y3 P: P$ R0 \# P7 L% ?) \0 ]8 L; a9 v/ q. ]6 w
    --------9 C7 v5 P1 R  y: l5 u

    " E( {3 b8 ~% P: TForcal代码:
    1. !using["math","sys"];8 F\\" D* D6 W, n, z. a; y. G
    2. mvar:
    3. 8 y\\" T' `: O# U* V
    4. main(:a)=
    5. . z/ G0 k- D9 t  n' Y
    6. t0=clock(),
    7. * f7 b, M$ f9 Z4 u! z4 i
    8. s=0,
    9. 8 K3 ~5 r4 u+ b, |' t
    10. k=0, while{k<1000,0 }1 f- e& j; J/ o
    11.   i=0, while{i<1000, a=linspace(2,2,1000), s=s+a.i, i++},  // 嗯,a.i 就是 a(i)
    12. * c; m5 ]; V7 k7 l
    13.   k++; M' t1 X# J4 o2 f. V+ ^
    14. },
    15. 4 o: w7 x! I8 k
    16. s;
    17. $ G* O- n) u. _) p( D! Z
    18. [clock()-t0]/1000;
    结果:( u6 ^; Q/ j9 ]# X( x
    2000000.) z* ]; N+ \6 r! L3 V- A4 l
    40.766 秒
    2 g7 C8 k, o7 J5 W( r9 h' n; D/ i0 P8 R8 G1 p$ z/ D
    程序运行时内存不稳定,时大时小。该程序导致Forcal垃圾收集器启动约10次,垃圾收集前内存消耗大,垃圾收集后内存小。
    * M, F9 d* K. P  [3 V& t因垃圾收集器多次启动,故耗时较长。* A) i7 c7 I( g" v/ Y, B3 f4 l9 |5 b
    + a( O( w( {3 Q
    ------------
    . ^' \2 _6 k* {$ L( Y3 X7 s' Y+ l# o8 j& R1 p
    以下将a=linspace(2,2,1000)放到了oo{  }函数中:
    1. !using["math","sys"];
    2. 9 Z& R% s$ V( [, D3 R6 `' f: X\\" G
    3. mvar:
    4. 5 t3 ], y) v0 n. \& j
    5. main(:a)=3 |( ?$ C( z) X- n4 H
    6. t0=clock(),
    7. 0 ]0 n# w$ n\\" p* K3 x/ y  S8 b9 H  |* k
    8. s=0,0 g. J\\" w1 ?3 \# c+ s* F) X
    9. k=0, while{k<1000,$ R; O* e& k, t5 @  @
    10.   i=0, while{i<1000, oo{a=linspace(2,2,1000)}, s=s+a.i, i++},  // 嗯,a.i就是a(i)2 w: ~# G9 O9 z  m& s+ Y
    11.   k++
    12. : q, @: h5 j8 T8 Q9 a
    13. },$ @$ {7 t8 o) f
    14. s;9 n# |5 S1 B, d\\" F\\" ?7 [
    15. [clock()-t0]/1000;
    结果:
    8 H4 }( f3 y; ^. d* D/ Q7 L. k8 g6 U2000000.
    0 q0 w8 n3 U6 i  u1 _9 k4.609 秒- ]4 Z' ^, o, e
    ) _0 q! q) m. b
    可以发现,Forcal耗时大大减少了,远小于matlab耗时,这要归功于oo{ }函数。0 M& c* G' L& N, M/ Y3 W& V
    在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 . v" K0 V/ H" i% ^$ `
    太强大了 看不懂啊
    / ~4 K: u- A# E0 z& v
    函数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
    # B; n7 c+ x5 u2 j3 O# S函数linspace(2,2,1000)放到循环里,每循环一次就会产生一个垃圾对象(一维数组),主要对比Matlab和Forc ...
    ( y" z7 ]; e; K1 G
    恩 我在研究研究,谢谢了
    回复

    使用道具 举报

    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 21:14 , Processed in 0.456891 second(s), 74 queries .

    回顶部