QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 8932|回复: 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
    这里用一个不太常用的小例子说明一下。0 k; s  F1 v* o1 M9 j1 I8 k; D
    ( g7 Q  ~  X% N# w4 v" A- C
    matlab 2009a代码:
    1. clear all6 c+ b. Q7 U  F5 v) A* P
    2. tic
      , F9 r+ }3 ~( P9 z
    3. s=0;
        ?( W# E; ?1 x% ]3 h* H, Y
    4. for k=1:1000
      * P5 _- {1 J* b$ J$ w% y* E
    5.   for i=1:10007 d: o6 N9 h) C3 m
    6.     a=linspace(2,2,1000);; \7 e8 k3 A' M+ }7 S9 T* b
    7.     s=s+a(i);
      6 K9 C  O. \, S
    8.   end- z2 H  M% d) u+ R& P7 Q
    9. end# h. g- [: J4 Z4 ]5 L: D
    10. s
      3 t& e. y! S- N+ d& I& C7 G
    11. toc
      7 u+ s+ W! \\" ^4 a- Y7 M! J$ Z; E
    12. 4 D; C) F1 F0 Z( I: A, Q4 [# F  ^
    13. s =8 ^, d. b8 Q' D, [$ G1 v
    14. . z2 L1 S: n0 p3 {. s4 J0 f! Y
    15.      2000000/ }: y$ f, P, E; Q1 ?) [

    16. # m+ I/ A. v8 D8 K7 l, {- r
    17. Elapsed time is 18.325900 seconds.
    复制代码
    程序运行时内存比较稳定。' i* d3 v. R7 p$ l% C

    * N; N# a3 a8 I* h, m--------
    5 O0 T( p! P) @/ u$ T
    5 h+ x$ m4 ?4 H$ d/ z2 G9 ZForcal代码:
    1. !using["math","sys"];
    2. . F8 B) Z& Z& x$ ^. v\\" [$ S
    3. mvar:# {' N' V! e. }\\" V6 `
    4. main(:a)=
    5. / H% A& \; a9 }# d$ v: l! j
    6. t0=clock(),
    7. ( `/ n, M9 \$ ?) T; v6 ?. v
    8. s=0,
    9. ) W4 l( q4 f4 h\\" l# [8 u& V
    10. k=0, while{k<1000,1 `; s! g, F+ @1 h& s6 M0 G: Z* V9 l
    11.   i=0, while{i<1000, a=linspace(2,2,1000), s=s+a.i, i++},  // 嗯,a.i 就是 a(i)
    12. 1 }. b\\" W/ E8 D
    13.   k++3 w- \9 }3 O/ k7 \, T: J
    14. },
    15. + u. ~5 ~  c) F6 G6 E+ o* s7 a, _
    16. s;) M; s8 X! S1 T/ U
    17. [clock()-t0]/1000;
    结果:
    & o2 c6 Q; T/ b1 J8 Z2000000.
    ) g/ B$ O, _" m  T, M40.766 秒
    2 D5 ~9 R. j4 _. ~/ O, h$ K* B" c  _9 {( G0 f
    程序运行时内存不稳定,时大时小。该程序导致Forcal垃圾收集器启动约10次,垃圾收集前内存消耗大,垃圾收集后内存小。8 u9 C% q' F% s9 d
    因垃圾收集器多次启动,故耗时较长。
    * A. o6 o* w' a6 |& c" f) `1 e4 Q2 |, e) E+ z# L
    ------------
    # |: D" Z  ?, u9 j# J; A8 l
    / E2 d5 w; |' l8 }. \以下将a=linspace(2,2,1000)放到了oo{  }函数中:
    1. !using["math","sys"];( u5 p. I; K; X6 h3 Q
    2. mvar:
    3. 0 J8 x! m1 s  U+ ?0 K8 O
    4. main(:a)=
    5. ( K' b2 t2 ^) i! C) f! f# ?
    6. t0=clock(),5 {# k+ l: t. ~9 r& @: @$ B
    7. s=0,
    8. 5 o- P1 P- H% t& ~/ R
    9. k=0, while{k<1000,+ X( ?9 u\\" ^* }$ n
    10.   i=0, while{i<1000, oo{a=linspace(2,2,1000)}, s=s+a.i, i++},  // 嗯,a.i就是a(i)
    11. % b\\" O- [4 N2 K8 l\\" J
    12.   k++' T' r) s# y& B2 l1 l$ r9 `. `& S
    13. },$ ^  y  ?9 ^\\" N' D0 L0 K
    14. s;, M3 w% Z: ^* b# k\\" ?- D  }: L
    15. [clock()-t0]/1000;
    结果:
    # \7 m. N9 R: T1 `) z: w% B2000000.5 |4 I: J- [( ~% L6 x
    4.609 秒( C; y3 S7 z7 S/ f. V% u

    ! N% G* @+ C5 j* P可以发现,Forcal耗时大大减少了,远小于matlab耗时,这要归功于oo{ }函数。
    : g( ]7 d5 @- g  A8 ?' o4 O在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
    2 q$ E, e+ f8 b! p6 ]& u太强大了 看不懂啊
    ) \' D+ Y+ u% P  r7 \& h
    函数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
    , F/ y/ m0 t( t; b函数linspace(2,2,1000)放到循环里,每循环一次就会产生一个垃圾对象(一维数组),主要对比Matlab和Forc ...

    ( x3 ?5 W1 w4 q8 F  D恩 我在研究研究,谢谢了
    回复

    使用道具 举报

    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-6-11 07:27 , Processed in 0.416122 second(s), 74 queries .

    回顶部