QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 4539|回复: 8
打印 上一主题 下一主题

【转载】加速matlab运行的三个境界

[复制链接]
字体大小: 正常 放大

1341

主题

738

听众

2万

积分

数学中国总编辑

  • TA的每日心情

    2016-11-18 10:46
  • 签到天数: 206 天

    [LV.7]常住居民III

    超级版主

    社区QQ达人 邮箱绑定达人 元老勋章 发帖功臣 新人进步奖 原创写作奖 最具活力勋章 风雨历程奖

    群组2011年第一期数学建模

    群组第一期sas基础实训课堂

    群组第二届数模基础实训

    群组2012第二期MCM/ICM优秀

    群组MCM优秀论文解析专题

    跳转到指定楼层
    1#
    发表于 2010-1-25 22:39 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta |邮箱已经成功绑定
    本帖最后由 厚积薄发 于 2010-1-25 22:54 编辑 7 Y* u! R. I3 M. z
    , P1 g( A% ]2 _2 A
    加速matlab运行的三重境界

    加速matlab运行的三重境界
    ; ~  r! s1 ]& S8 s% ~: J2 i; m4 r%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
    " {3 {# {8 H" t- w3 Q$ @2 A%%%%%%%%%%%%%%%%%%%%%%%
    1 X  q- w" d& c6 @! i! `/ f( `
    一、 遵守Performance Acceleration的规则; o) W" f. m- ]3 H/ q$ {" P
    二、 遵守三条规则
    + i% J" }: c  G! @+ O三、 绝招, p/ f1 F& z' U7 M4 h! r. [" N
    %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
    ; h& A" t2 S7 c, N0 K' {% G$ E%%%%%%%%%%%%%%%%%%%%%%%

    一、 遵守Performance Acceleration的规则, [8 d3 [& G' u9 m( h5 M! n6 Z* t
    关于什么是“Performance Acceleration”请参阅matlab的帮助文件。我只简要的将/ A. r3 I8 A6 _8 b% S% X) v0 C
    其规则总结如下7条:, i& d- t6 d& D
    1、只有使用以下数据类型,matlab才会对其加速:6 p: Y4 @4 N, o& ~0 T. B& \9 G, l
    logical,char,int8,uint8,int16,uint16,int32,uint32,double
    % N( c% Z/ E- T
    而语句中如果使用了非以上的数据类型则不会加速,如:numeric,cell,structu8 \, r& n+ I7 j: ^3 ]- ?
    re,single,
    * F9 l/ J- x% }- Z7 wfunction handle,java classes,user classes,int64,uint645 K- k. ?. g: h- U
    2
    matlab不会对超过三维的数组进行加速。

    9 d9 ~5 t. h% Z) y( x% z+ ^0 H3、当使用for循环时,只有遵守以下规则才会被加速:afor循环的范围只用标量值
    - ], ]2 ^8 S/ }( I. w, `' F来表示;' G+ u% w* ~0 Q3 v$ Z+ ~
    bfor循环内部的每一条语句都要满足上面的两条规则,即只使用支持加速的数
    0 L. B9 C& R3 U: i0 `据类型,只使用+ O( L; x+ v7 O6 ?5 R, T* c; Z
    三维以下的数组;c、循环内只调用了内建函数(build-in function)。) R* e/ j+ ?& ]0 v; s6 D
    4、当使用ifelseifwhileswitch时,其条件测试语句中只使用了标量值时,将3 g0 V* G, J9 _; c* i0 L
    加速运行。
    / i' {7 \) P& }( j  c5、不要在一行中写入多条操作,这样会减慢运行速度。即不要有这样的语句:7 _9 H$ V$ Y  C2 n0 H2 [
    x = a.name; for k=1:10000, sin(A(k)), end;
    ' ^+ N4 T! I* R, p  G0 e  R6
    、当某条操作改变了原来变量的数据类型或形状(大小,维数)时将会减慢运行速
    2 |, N! A$ @# _: e+ X- ^度。8 h9 [1 o9 A" a
    7、应该这样使用复常量x = 7 + 2i,而不应该这样使用:x = 7 + 2*i,后者会降低
    % _2 ^+ T) h3 f2 k/ I) ?运行速度。
    : E7 b, W" s  V1 G; x%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%# u' d/ I# [6 S. H' C
    %%%%%%%%%%%%%%%%%%%%%%%
    : T) T- _2 Q& P; b, D/ ^0 M4 k. Z' k
    二、 遵守三条规则3 {3 @! Q% h, Z( s& E; }# k
    1、尽量避免使用循环,MATLAB的文档中写到“MATLAB is a matrix language, whic6 S6 G) O. W/ {  v8 m
    h means it is designed
    ! P+ H9 i' G1 i" ^; T" [% @4 Efor vector and matrix operations. You can often speed up your M-file c/ O' e% N. y7 o4 D# R5 n/ Z
    ode by using5 Q& K; o$ L/ @8 D
    vectorizing algorithms that take advantage of this design. Vectorizati6 k  m# \& e; ]* b4 w0 T# Q$ X
    on means converting
    " q1 U4 e+ p# }' a+ rfor and while loops to equivalent vector or matrix operations.”
    。改进

    ( b3 S# k8 b1 P8 A& J8 S: l" X这样的状况有两种方法:
    , g/ t0 {2 K3 g2 O: W. |1 _" @6 ua、尽量用向量化的运算来代替循环操作。如将下面的程序:
    ! V0 Y$ k- b( S  n9 ~i=0;  H6 L' v( r; b6 f3 ~" m$ M
    for t = 0:.01:106 ^5 N7 m* N1 C6 ?0 ~& d0 Q) c
    i = i+1;- g: r, n  r! }+ v3 w
    y(i) = sin(t);
    + u- A1 J7 E5 d# D  Jend
    4 s0 U0 ^1 v2 k$ I6 {
    替换为:
    4 @2 R0 ^! A0 a4 S6 R" X* y" o' {3 Dt = 0:.01:10;
    ; y- r8 C' [8 ^7 Ly = sin(t);
    & k5 t. _1 F& d. Q
    速度将会大大加快。最常用的使用vectorizing技术的函数有:Alldiffi- s9 I  F0 N8 A' T9 n
    permute
    permute
    ) C0 U, X' c: A0 }9 D5 g
    reshapesqueezeanyfindlogicalprodshiftdimsub2indcums; ?+ G+ N  l/ f. Y/ @% r4 z( [
    um
    ind2sub
    + g3 H+ N) [+ g& _+ h  W
    ndgridrepmatsortsum 等。
    3 a' z3 w8 |; R7 }2 V请注意matlan文档中还有这样一句补充:“Before taking the time to
    + v( A2 h3 v6 g; h9 X0 [1 @  r0 vvectorize your code, read the section on Performance Acceleration.
    & E6 Z' h* P0 ?: Q0 }: RYou may be able to
    / n5 G. X& Q3 Q% E$ Pspeed up your program by just as much using the MATLAB JIT Accelera
    $ h5 q6 H, P0 f  Z' F' qtor instead of
    : }. P6 w) b5 S) ~; Tvectorizing.”
    。何去何从,自己把握。
    + F$ @' D5 T. t: g* |+ |$ T! R# s
    b、在必须使用多重循环时下,如果两个循环执行的次数不同,则在循环的外环执" {+ _! R+ B3 r" z( I
    行循环次数少的,
    # s) N: `/ w+ X+ Q1 x1 h; D! `- ^内环执行循环次数多的。这样可以显著提高速度。
    ; ^* G2 o4 C9 z; h) V2a、预分配矩阵空间,即事先确定变量的大小,维数。这一类的函数有zeroson
    / u! v0 c( V- W; ^1 h. Tes
    cellstruct
    * x) ^; r7 {  Z, Q
    repmat等。
    $ |/ D* ?: A: j% l! ]& M+ cb、当要预分配一个非double型变量时使用repmat函数以加速,如将以下代码:
    $ N8 ^7 q, L+ ?& q. sA = int8(zeros(100));
    . s8 v, c- p  `8 W7 m" o) @, H1 M
    换成:
    . S( [5 t1 A( I( ?6 l. D5 }! _5 EA = repmat(int8(0), 100, 100);. V8 D0 s0 h% u) b# Z% P8 Y
    c
    、当需要扩充一个变量的大小、维数时使用repmat函数。0 M3 G- z; Q! p4 k
    3a、优先使用matlab内建函数,将耗时的循环编写进MEX-File中以获得加速。
    3 V# x' O0 s" L& q8 L5 O. Y0 tb、使用Functions而不是Scripts
    8 k. A5 f6 j' @! }2 ]$ O+ F%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%& C3 @8 S! ^) E; Y( \# C, e0 _
    %%%%%%%%%%%%%%%%%%%%%%%
    ) A/ s* U! y$ a2 H; T. H# v4 W3 k4 V
    三、 绝招% j8 R, M4 ]* w
    你也许觉得下面两条是屁话,但有时候它真的是解决问题的最好方法。% F1 f! L9 }/ @. U
    1、改用更有效的算法
    - q, R! Z2 M' u2 G1 `1 m- c! m2、采用Mex技术,或者利用matlab提供的工具将程序转化为C语言、Fortran语言。


    * U8 H$ L8 h) I. \' h6 T+ \+ u) ?0 B9 J) v- q
      来源:iLoveMatlab
    , `* D- r( y0 ^
    / _6 E" S! n8 N& N* e0 ~
      ?. G) M# e; v$ r/ a/ V, n在这里本人推荐使用‘绝招’。
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    XINGQIBIN 实名认证       

    0

    主题

    5

    听众

    94

    积分

    升级  93.68%

    该用户从未签到

    群组数模应用

    回复

    使用道具 举报

    HSinB 实名认证       

    0

    主题

    5

    听众

    1651

    积分

    升级  65.1%

  • TA的每日心情
    开心
    2012-2-9 17:19
  • 签到天数: 2 天

    [LV.1]初来乍到

    新人进步奖 发帖功臣

    回复

    使用道具 举报

    D-lin 实名认证       

    22

    主题

    5

    听众

    465

    积分

    升级  55%

    该用户从未签到

    自我介绍
    人称玉树临风胜潘安,一支梨花压海棠

    新人进步奖

    回复

    使用道具 举报

    leo12ok 实名认证       

    3

    主题

    4

    听众

    556

    积分

    升级  85.33%

  • TA的每日心情
    擦汗
    2012-6-14 16:31
  • 签到天数: 1 天

    [LV.1]初来乍到

    自我介绍
    200 字节以内

    不支持自定义 Discuz! 代码

    新人进步奖

    回复

    使用道具 举报

    0

    主题

    3

    听众

    95

    积分

    升级  94.74%

    该用户从未签到

    自我介绍
    嘿嘿~  可爱的我~
    回复

    使用道具 举报

    isnowfy 实名认证       

    6

    主题

    4

    听众

    473

    积分

    升级  57.67%

  • TA的每日心情
    开心
    2013-3-7 02:00
  • 签到天数: 1 天

    [LV.1]初来乍到

    自我介绍
    200 字节以内
    不支持自定义 Discuz! 代码

    新人进步奖 最具活力勋章 发帖功臣

    群组Matlab讨论组

    mark。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。
    回复

    使用道具 举报

    27

    主题

    4

    听众

    196

    积分

    升级  48%

    该用户从未签到

    收藏了~~~对现在建模很有用……我上次写的程序就运行了N久都没出结果……郁闷……
    回复

    使用道具 举报

    schnee        

    0

    主题

    4

    听众

    241

    积分

    升级  70.5%

  • TA的每日心情
    开心
    2013-9-3 12:40
  • 签到天数: 18 天

    [LV.4]偶尔看看III

    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-5-25 17:25 , Processed in 0.785096 second(s), 100 queries .

    回顶部