QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 4541|回复: 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 编辑 6 K" o; T# y8 O
    2 W9 x# S; ^: D9 z& y
    加速matlab运行的三重境界

    加速matlab运行的三重境界; K! W% ^, e4 O9 G0 ?0 t* Z6 A* [8 Y% N
    %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%6 M; q3 y* w1 a4 s( L. b+ {* y
    %%%%%%%%%%%%%%%%%%%%%%%
    9 ]5 }. q2 x6 e; E2 C, f' A
    一、 遵守Performance Acceleration的规则. v9 G$ Z1 ?4 T$ y, @
    二、 遵守三条规则7 f0 M- J, D* J4 ?+ P( C
    三、 绝招8 T$ T* c0 M/ Y5 d' Z6 B& b
    %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
    1 k& i; c8 N1 A8 D%%%%%%%%%%%%%%%%%%%%%%%

    一、 遵守Performance Acceleration的规则1 Q" Y8 b! b) y, g. b
    关于什么是“Performance Acceleration”请参阅matlab的帮助文件。我只简要的将
      J& S9 P  S( r7 v* |其规则总结如下7条:
    8 s3 z# I' S: M7 R1、只有使用以下数据类型,matlab才会对其加速:
    ' A2 t, p. M% n! xlogical,char,int8,uint8,int16,uint16,int32,uint32,double, e% K. n% z; z% X  m0 ?
    而语句中如果使用了非以上的数据类型则不会加速,如:numeric,cell,structu
    , w8 A2 L, z8 T; w* I% D% pre,single,
    * E0 v  L( E" r; c4 [function handle,java classes,user classes,int64,uint64
    7 r8 \5 \: U- P% U9 L% @7 G/ n2
    matlab不会对超过三维的数组进行加速。

    3 W: n  s8 @' d8 ]3、当使用for循环时,只有遵守以下规则才会被加速:afor循环的范围只用标量值7 m& ]8 {% A1 X3 w
    来表示;" E& L" D  W/ A: j5 M. g2 ?
    bfor循环内部的每一条语句都要满足上面的两条规则,即只使用支持加速的数; J. q/ j1 p! d9 L7 t/ p. U
    据类型,只使用
    + l% A! o4 q. \6 N; n7 z三维以下的数组;c、循环内只调用了内建函数(build-in function)。# V7 ^3 U4 X! o" s* e) O  t1 A
    4、当使用ifelseifwhileswitch时,其条件测试语句中只使用了标量值时,将  c( R* }& j5 R4 f6 c/ x
    加速运行。& \2 `1 F+ r6 l- G/ q" f- ]4 V
    5、不要在一行中写入多条操作,这样会减慢运行速度。即不要有这样的语句:. B& S$ L: O8 t6 O3 c- g0 i
    x = a.name; for k=1:10000, sin(A(k)), end;
    $ |; t$ s; N( {# }8 P7 n- h' k6
    、当某条操作改变了原来变量的数据类型或形状(大小,维数)时将会减慢运行速
    - l  {: O& r* h4 j" d: I度。
    8 d& ^  r6 \3 c, `- z7、应该这样使用复常量x = 7 + 2i,而不应该这样使用:x = 7 + 2*i,后者会降低* S5 ]2 S" R% a- }9 [. k
    运行速度。& O1 s0 W$ I* [) p
    %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
    ) F, U1 }( r- s4 g5 N  h%%%%%%%%%%%%%%%%%%%%%%%  N8 m1 g8 D1 U' V
    二、 遵守三条规则* B7 I+ ]* E: W( R$ x3 X
    1、尽量避免使用循环,MATLAB的文档中写到“MATLAB is a matrix language, whic7 r: B4 }) m6 U( ?0 m% A$ v  O
    h means it is designed
    ) k% _0 y% o- x9 d0 l% _1 zfor vector and matrix operations. You can often speed up your M-file c
      t( g' T8 T" Lode by using
    ( Q0 {! G( O) S2 I  fvectorizing algorithms that take advantage of this design. Vectorizati* w7 Z& E9 J" p+ C$ u
    on means converting2 u, X# x% s  \6 J1 z; C% l7 H  Q
    for and while loops to equivalent vector or matrix operations.”
    。改进

    8 \6 ]' ^# k0 J这样的状况有两种方法:8 ~* [9 m; b2 G  {
    a、尽量用向量化的运算来代替循环操作。如将下面的程序:
    ( k& s8 D1 L5 t5 \: Zi=0;
    2 ^; W' K/ B9 K3 J5 f0 jfor t = 0:.01:10
    * F/ w) l6 l) A( _- Li = i+1;1 [8 K  T" y0 r: B6 ^
    y(i) = sin(t);
    6 w+ P0 T3 f4 hend
    ( U: a8 m6 S- t1 n6 d
    替换为:
    # b5 K5 h$ J) @+ I' _0 s. ]t = 0:.01:10;+ C, g: i9 r4 c. r& x  r! i
    y = sin(t);$ R, _& h8 l6 H
    速度将会大大加快。最常用的使用vectorizing技术的函数有:Alldiffi8 e7 m/ |& `- }4 a9 C2 O- X  h
    permute
    permute
    & J1 c. ]2 d* _; t$ ]
    reshapesqueezeanyfindlogicalprodshiftdimsub2indcums
    : c- ~* C; i! [; Z* V( ^/ ?um
    ind2sub

    ( y! [7 G/ y6 L4 @- Tndgridrepmatsortsum 等。( F) E' p% c, G3 ]5 E; g4 v" J- r
    请注意matlan文档中还有这样一句补充:“Before taking the time to: M/ @6 A% J+ U; P% Z2 k( j
    vectorize your code, read the section on Performance Acceleration.* W! \4 z! o. g7 @* K+ i
    You may be able to, J) j* |, n: k8 G
    speed up your program by just as much using the MATLAB JIT Accelera
    - c/ ^" |8 W; q1 Ytor instead of
    9 r  g0 T3 _, a1 Xvectorizing.”
    。何去何从,自己把握。
    1 ^( B/ I: |9 v) H4 n! j; P  P8 g
    b、在必须使用多重循环时下,如果两个循环执行的次数不同,则在循环的外环执
    $ _; g5 H( `3 p% \5 U; f/ {# B+ j行循环次数少的,
    * E3 u" r  H) J- n9 n* I3 d3 U内环执行循环次数多的。这样可以显著提高速度。
    # n- B7 p* `. i( O8 ~) Y" m. K2a、预分配矩阵空间,即事先确定变量的大小,维数。这一类的函数有zeroson9 n% |& ^+ m! _5 m) h' Z2 ?4 K
    es
    cellstruct

    8 y  l  w3 k8 d6 Orepmat等。
    , ~- P5 Y4 @1 O' ub、当要预分配一个非double型变量时使用repmat函数以加速,如将以下代码:6 Y9 k3 D# D+ L8 W: b
    A = int8(zeros(100));
    2 ?# G! Y: z, f1 l2 m( ?
    换成:
    - t7 _8 q" [- q, L, }/ CA = repmat(int8(0), 100, 100);: I/ v( Y8 k1 p
    c
    、当需要扩充一个变量的大小、维数时使用repmat函数。, `3 l2 K1 j" H! J' m5 S( E
    3a、优先使用matlab内建函数,将耗时的循环编写进MEX-File中以获得加速。, G5 ]! K" c& Q- d* }
    b、使用Functions而不是Scripts
    ; U$ a# j4 m3 u9 u8 h%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%5 {7 }5 O: G$ X, c7 k& s3 d
    %%%%%%%%%%%%%%%%%%%%%%%0 s5 V* D# k& N& ?) V0 N
    三、 绝招; s# S9 M: ]( B5 D% h* |0 j" f# h" W
    你也许觉得下面两条是屁话,但有时候它真的是解决问题的最好方法。+ T: R0 Y6 L+ S8 h! }: e" Y
    1、改用更有效的算法3 M2 D- ?0 Z5 }3 s
    2、采用Mex技术,或者利用matlab提供的工具将程序转化为C语言、Fortran语言。


    , Q. p7 Q! |; k2 Y$ y
    0 l1 p- W( P, {$ q2 w$ k' e6 x1 @  来源:iLoveMatlab' P9 ?1 M) W# M; h1 M. Y
    ! _  I, f" p3 ^  f" B
    6 P, q, y2 S$ Q& T2 |
    在这里本人推荐使用‘绝招’。
    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 22:04 , Processed in 0.500592 second(s), 105 queries .

    回顶部