QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 8674|回复: 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
    这里用一个不太常用的小例子说明一下。
    5 _% l/ @  K' h, ?$ K' Y9 {5 h" o& a7 _0 o, S  K) R7 y
    matlab 2009a代码:
    1. clear all
      * p0 R$ d3 Y  Q
    2. tic1 v& p. W$ C\" D5 K0 u. d
    3. s=0;, }9 f* l( y6 N6 I8 ^
    4. for k=1:1000
      ; L$ d  Y2 z; w+ L8 ?, b2 p
    5.   for i=1:1000
      ) {5 X1 i, H  g/ I% S5 U
    6.     a=linspace(2,2,1000);
      2 K# _- `: X' u0 h. W\" U
    7.     s=s+a(i);
      / X; v/ M, N4 ~3 S( v
    8.   end$ o1 S\" G* z! m# k1 B. t
    9. end& K$ e( a3 w* z( T, O4 C/ }
    10. s+ C% k- _6 G+ S: S
    11. toc
      8 ]% L5 u. N! F( ~5 i6 I: J

    12. - z- t\" m( S. G8 d8 T) J/ R
    13. s =
      # E  r0 A8 g! K( z! a8 B, ~
    14. * P# o' h8 Z+ y* X, ]' I3 O
    15.      2000000
      . B# U* M\" \+ G. F
    16. % ~) y7 w\" [) m0 i7 u. N3 s8 j+ D
    17. Elapsed time is 18.325900 seconds.
    复制代码
    程序运行时内存比较稳定。0 S+ e1 N1 n/ g6 b+ v" m
    8 O9 q# ?8 {( n& G0 H) b
    --------
    / r1 g* |) A' U+ N# w4 b% V( d6 i8 L. a  `* G/ l
    Forcal代码:
    1. !using["math","sys"];
    2. . K: ?+ g, Q\\" e* N( L
    3. mvar:
    4. ! g8 I8 l8 k) Y3 J3 }
    5. main(:a)=2 L* {0 S* I1 C3 X7 k5 T* {0 I- G' [
    6. t0=clock(),1 A7 h% U: w) E3 Y8 Y
    7. s=0,7 u2 f) i* m/ m% v5 W; N+ \2 w2 g: x9 M
    8. k=0, while{k<1000,
    9. + \% C5 ?( t' K\\" Q
    10.   i=0, while{i<1000, a=linspace(2,2,1000), s=s+a.i, i++},  // 嗯,a.i 就是 a(i)
    11. - _4 F' G\\" C2 w
    12.   k++9 B7 O, G8 h1 m
    13. },# M  Z! l1 O  ?7 \2 Z5 @- w9 {
    14. s;! k: \/ s- l6 J6 c9 V& X4 V1 P3 M
    15. [clock()-t0]/1000;
    结果:
    * _. S) u2 N# b( s* @2000000.
    7 b# n. H+ ]# l0 Y& @40.766 秒4 m$ v- n* e* G) z( ?
    ( M; x3 E4 E1 N' J
    程序运行时内存不稳定,时大时小。该程序导致Forcal垃圾收集器启动约10次,垃圾收集前内存消耗大,垃圾收集后内存小。
    ; E+ }; u) a; b- }; a6 m) k因垃圾收集器多次启动,故耗时较长。
      V* F8 n! \- b* A
    8 b; J) I0 d, M& \& O------------
    4 o5 z: m9 n7 u7 K
    * ~5 @( C/ H3 w8 j" O以下将a=linspace(2,2,1000)放到了oo{  }函数中:
    1. !using["math","sys"];
    2. : u$ G% n1 i( p& j  @! b# O5 z' U
    3. mvar:
    4. 7 t+ T: H- F4 y, D% E& ^
    5. main(:a)=& }7 Q. H# n, B6 n; |
    6. t0=clock(),# M  }& W. K  @: F6 g( J
    7. s=0,
    8. ! M; h% W5 d7 C- N) b3 X
    9. k=0, while{k<1000,
    10. + @3 \' B2 Z3 Y/ l: M5 Z4 T
    11.   i=0, while{i<1000, oo{a=linspace(2,2,1000)}, s=s+a.i, i++},  // 嗯,a.i就是a(i)
    12. \\" V) L4 U' f4 {! O. g$ `
    13.   k++
    14.   F8 e  E$ n: K6 f3 m6 `/ a
    15. },
    16. 8 P8 d$ z9 N; G- }5 _
    17. s;8 O  F\\" ]5 I; f! D5 ?$ a& o
    18. [clock()-t0]/1000;
    结果:
    / W5 e( `2 ~6 G2 z( A( X+ f$ C2000000.
    9 E! f5 z2 U' G9 }+ m* d3 S4.609 秒! L) F. H0 d; b$ J( P
    + a- L2 i  T  M# q' p. F
    可以发现,Forcal耗时大大减少了,远小于matlab耗时,这要归功于oo{ }函数。( }* i' B7 [8 R2 [5 I/ q
    在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 1 M9 U% T( z% L: b8 g6 V
    太强大了 看不懂啊

    6 k7 M6 ^! B) w, l: o% }. j' x函数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 ( K9 U- H4 y( Z4 t! c3 z
    函数linspace(2,2,1000)放到循环里,每循环一次就会产生一个垃圾对象(一维数组),主要对比Matlab和Forc ...
    ) d& t+ D) E4 u3 }7 J! _
    恩 我在研究研究,谢谢了
    回复

    使用道具 举报

    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-15 22:17 , Processed in 1.210996 second(s), 74 queries .

    回顶部