QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 8855|回复: 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
    这里用一个不太常用的小例子说明一下。
      K3 Z- @8 C) v; `
    9 }8 F" x& c# k9 J, Bmatlab 2009a代码:
    1. clear all; n% r4 b4 f7 ~2 S+ v% A- x# z
    2. tic
      ; h, Z% N) L% c+ i/ t8 v& L
    3. s=0;+ I- M& T) u$ q+ Y( V
    4. for k=1:1000
      % W1 G$ ~) E- ~+ k3 T% y; W
    5.   for i=1:1000
      6 M( W% K4 {\" D
    6.     a=linspace(2,2,1000);9 I3 F# j  d3 n# N' \  B2 V$ [; b\" `) a
    7.     s=s+a(i);
      / o! z/ L; s0 B7 y5 X6 Y
    8.   end. u1 t6 t7 a' n
    9. end# U& @: \' S  a
    10. s
      ) i5 }$ L( W9 T' D9 }
    11. toc5 T% p: y4 N3 x4 ~
    12. . }9 T- H9 y( i5 R4 ]\" h0 Z5 q
    13. s =
      / s3 m% F4 r$ ?\" Z2 i\" M9 p

    14. 9 d) e4 U- E8 N5 y1 ?9 I# Q
    15.      2000000
      , T9 D5 a+ ~; C) i\" F# ]* x) _\" |/ c

    16. # p1 J# d2 V- Q, o  _8 ?
    17. Elapsed time is 18.325900 seconds.
    复制代码
    程序运行时内存比较稳定。, E, m4 {, z* p: m/ F: r

    6 c- J* \8 z/ x* o/ ?1 J! o--------4 s, g6 ?7 d$ O, x% I4 J' `

    ! M. d. e* J' J9 O. B( z1 FForcal代码:
    1. !using["math","sys"];$ x- V/ q& T8 s( p) z# [# Z  D
    2. mvar:/ H+ q# X3 |, m& m1 E
    3. main(:a)=
    4. # c! ?* W; F& ]' U) C0 S) Q
    5. t0=clock(),
    6. ; J0 F6 B, F( d' E0 S
    7. s=0,
    8. * X% t+ m' h' n, D! B
    9. k=0, while{k<1000,, s! k6 Y* D+ s* q9 W
    10.   i=0, while{i<1000, a=linspace(2,2,1000), s=s+a.i, i++},  // 嗯,a.i 就是 a(i)! h% w' B\\" J+ S$ q4 @) t
    11.   k++
    12. ( _2 c3 \9 [- y) Z) C1 W' f- n
    13. },
    14. 7 M# ]) `6 L: b; i1 C, \0 ~
    15. s;) u% e! }- O1 I! q2 ?
    16. [clock()-t0]/1000;
    结果:+ H9 x. T' h3 G
    2000000., D1 m2 D/ j0 ^
    40.766 秒
    4 |! D! S, G1 q! M: x
    ) a* C. C5 i- X# a" B8 K程序运行时内存不稳定,时大时小。该程序导致Forcal垃圾收集器启动约10次,垃圾收集前内存消耗大,垃圾收集后内存小。. J4 @  e0 J! {! A" Q% I: I
    因垃圾收集器多次启动,故耗时较长。  b. U' U7 O# B5 {/ f' c

    " }% J0 b& y6 }------------5 k/ P: C2 L7 ~! |8 [! D' M
    & k0 e  R/ P6 V* Y' o
    以下将a=linspace(2,2,1000)放到了oo{  }函数中:
    1. !using["math","sys"];4 d* L/ F# e7 i1 d. t
    2. mvar:
    3. / a9 ]8 ?3 a. G9 a' r
    4. main(:a)=0 c: [. g0 m9 `, S7 C0 A  c- }$ G; S5 m
    5. t0=clock(),$ o/ m  }\\" x0 H, L0 K2 H
    6. s=0,+ v$ [\\" T0 R! Z0 u5 _7 v  h; }
    7. k=0, while{k<1000,$ G- G, d: U8 c1 J
    8.   i=0, while{i<1000, oo{a=linspace(2,2,1000)}, s=s+a.i, i++},  // 嗯,a.i就是a(i)
    9. ' Z$ y$ {9 w8 Y$ [/ {  `: g( V
    10.   k++$ {. N- Y) @, z5 P: D
    11. },; }; a# Q0 J- L$ v: K
    12. s;
    13. ( P1 G% z8 X6 [4 {9 S
    14. [clock()-t0]/1000;
    结果:9 E) R0 r$ T$ b, N# U: g
    2000000.) x- T' Y  w0 q* e# T/ D! d
    4.609 秒
    / G$ u* {8 o- \7 K' w" q" U& H2 q1 N) J6 l1 s7 o
    可以发现,Forcal耗时大大减少了,远小于matlab耗时,这要归功于oo{ }函数。
    ) }( F% L! v$ ^# `0 ~9 E8 ?在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
    ; z! M9 }" O/ r太强大了 看不懂啊
    ! u8 Z& q% P% S
    函数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
    - \& U" ?4 ~# P2 v6 t+ Q" H% A3 R$ L函数linspace(2,2,1000)放到循环里,每循环一次就会产生一个垃圾对象(一维数组),主要对比Matlab和Forc ...
    " @6 k7 T, U% N4 ~6 |( O9 ?. 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, 2026-4-19 12:48 , Processed in 1.508511 second(s), 74 queries .

    回顶部