QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 4334|回复: 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 编辑
    ( e6 s+ S4 f  g( [9 I
    * e- ?. F8 J/ G7 r( f$ u6 B9 N加速matlab运行的三重境界

    加速matlab运行的三重境界
    5 u) C* x# V9 i- K$ z! W%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%7 P$ F1 o9 P$ C
    %%%%%%%%%%%%%%%%%%%%%%%( K0 v# v0 i4 F
    一、 遵守Performance Acceleration的规则& ~/ ~" Y) G& r/ b/ \" v
    二、 遵守三条规则
    2 y% \0 o. Z# R5 G9 e' p/ }三、 绝招
    . u- p* ~) e- M6 ]3 H%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
    ; I$ F( u6 t9 ^, U1 V" {: ?" N4 s%%%%%%%%%%%%%%%%%%%%%%%

    一、 遵守Performance Acceleration的规则
    8 _( P- E( b2 ?. L( p1 Q5 v关于什么是“Performance Acceleration”请参阅matlab的帮助文件。我只简要的将+ {' Y5 G* T- o* {. H
    其规则总结如下7条:& R: f0 H! i" A: [: y7 _4 z+ h
    1、只有使用以下数据类型,matlab才会对其加速:1 `8 q* L! _, s8 g/ s' N
    logical,char,int8,uint8,int16,uint16,int32,uint32,double. ?" W9 m8 C# Z$ s2 M7 e
    而语句中如果使用了非以上的数据类型则不会加速,如:numeric,cell,structu% `2 L; U% V! @: D+ W3 z, P$ ^
    re,single,
    . C6 X9 e/ w) P4 u+ ?' tfunction handle,java classes,user classes,int64,uint64: ^, k. N) K6 A" U8 C
    2
    matlab不会对超过三维的数组进行加速。

    " j- C. n8 x2 J2 u/ a9 H. I$ o3、当使用for循环时,只有遵守以下规则才会被加速:afor循环的范围只用标量值
    / {6 ?. H( x) e4 F' i0 x2 ~$ I: F+ W来表示;
    . ?* V! U5 f( e( h+ u3 T, Wbfor循环内部的每一条语句都要满足上面的两条规则,即只使用支持加速的数
    . ^5 ]% C4 ]' V' u9 {9 j据类型,只使用# H; N/ ~0 a9 R- @$ r9 b
    三维以下的数组;c、循环内只调用了内建函数(build-in function)。$ O8 L3 B" i' E0 Q' k
    4、当使用ifelseifwhileswitch时,其条件测试语句中只使用了标量值时,将
      \+ b. B9 H. u  `/ x加速运行。1 l; \' C9 f) e* C- A% F% q% u
    5、不要在一行中写入多条操作,这样会减慢运行速度。即不要有这样的语句:8 f* ?4 O. T2 r, Y
    x = a.name; for k=1:10000, sin(A(k)), end;8 N; t+ y8 B$ R& Q  s! D7 n  G/ l) T! D
    6
    、当某条操作改变了原来变量的数据类型或形状(大小,维数)时将会减慢运行速
    & c$ K0 z# d( p+ s度。
    2 }# v, {0 J6 u# m) r) t( J7、应该这样使用复常量x = 7 + 2i,而不应该这样使用:x = 7 + 2*i,后者会降低) z# O& a) E+ ^
    运行速度。1 E- T* v" V& v
    %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%8 @  b7 c# R8 N9 p
    %%%%%%%%%%%%%%%%%%%%%%%
    / V! l5 Z6 d4 c- ]- @/ Q
    二、 遵守三条规则( M; p& |1 O" d) |* [. o
    1、尽量避免使用循环,MATLAB的文档中写到“MATLAB is a matrix language, whic
      w- P# O" ~8 \# L3 \h means it is designed4 t9 S- T0 l/ A2 G
    for vector and matrix operations. You can often speed up your M-file c
    & ~& N" ~. p2 L4 e5 O) Fode by using
    - w5 E1 z1 ?3 A3 b  L( x+ nvectorizing algorithms that take advantage of this design. Vectorizati
    6 C; X! ]2 o; Q. P* N% Z# Pon means converting
      B( A2 Y0 O! O4 O5 \$ gfor and while loops to equivalent vector or matrix operations.”
    。改进
    9 s8 m% `( C. e+ j
    这样的状况有两种方法:
    $ {8 P! b1 w5 H, n1 Y' w" d$ ja、尽量用向量化的运算来代替循环操作。如将下面的程序:9 `2 j9 X8 k/ I5 s! z2 @
    i=0;
    9 c; O* @3 `  V/ vfor t = 0:.01:10: g  T8 H% r5 }
    i = i+1;* I5 W  O- n5 a1 q
    y(i) = sin(t);0 G. `  o+ S- T/ [* `. ^. O
    end
    ' r+ H- _6 p6 G1 Z) R6 M0 B
    替换为:
    3 ?8 Z0 m( ^$ Y1 w; R" ]t = 0:.01:10;: {! ^. e' s/ n* Z! D; J3 ]3 h: o
    y = sin(t);
    , N# j' Z9 ~8 e) i1 B& R; K
    速度将会大大加快。最常用的使用vectorizing技术的函数有:Alldiffi
    9 y8 N3 o6 o# Y. P4 t4 w8 Rpermute
    permute
    # _) O. p2 M6 P3 e7 v# c* \5 S# H" k
    reshapesqueezeanyfindlogicalprodshiftdimsub2indcums
    9 `( A9 j7 [2 z( Zum
    ind2sub
    # y3 D6 C. h  n
    ndgridrepmatsortsum 等。, \7 G, Z) ?9 X$ k- k, s
    请注意matlan文档中还有这样一句补充:“Before taking the time to
    + {% v+ E) i1 ^5 c% I8 h3 H: N/ }vectorize your code, read the section on Performance Acceleration.
    , c  q  N' r" ~' l* S' d5 l7 x/ }You may be able to
    ( b4 K9 p3 S6 u4 I0 k$ d* x/ n# [1 mspeed up your program by just as much using the MATLAB JIT Accelera+ x0 t( f' H, j3 `4 ~  {" V
    tor instead of3 b4 O7 Y7 a+ h* X3 u' i: H
    vectorizing.”
    。何去何从,自己把握。

    5 A% B: |" |$ W. Z8 w* z* Nb、在必须使用多重循环时下,如果两个循环执行的次数不同,则在循环的外环执
    8 Y& `, w! e- ~- t' d) {3 K行循环次数少的,: E! _8 U! J3 ^8 [2 m
    内环执行循环次数多的。这样可以显著提高速度。
    6 c6 E* D; y+ u" T2a、预分配矩阵空间,即事先确定变量的大小,维数。这一类的函数有zeroson
    & \% p7 y; x! X6 H: T/ ~, T3 Mes
    cellstruct
    ; x  S/ y: _# E, }; L8 P+ a% l& e+ V
    repmat等。/ T2 r3 U( Y/ g9 s5 a" E
    b、当要预分配一个非double型变量时使用repmat函数以加速,如将以下代码:+ h: Y) |3 q' E& Q: F" t
    A = int8(zeros(100));
    - I$ l$ Z! I. a  f) l6 J
    换成:
    3 }1 T* \  M7 ]4 B7 u0 aA = repmat(int8(0), 100, 100);
    $ m/ h( s* W. bc
    、当需要扩充一个变量的大小、维数时使用repmat函数。
    7 v5 @. r4 k# a) @; r' |3a、优先使用matlab内建函数,将耗时的循环编写进MEX-File中以获得加速。' v. Z$ ~: \! r0 m) ]: C
    b、使用Functions而不是Scripts 2 @3 g' ]- w- d0 H6 T
    %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%0 o* Y, C, n" Q
    %%%%%%%%%%%%%%%%%%%%%%%
      z$ R0 e9 Z' K2 Y4 A$ a
    三、 绝招# e. }6 N' w" v! ~' P3 I
    你也许觉得下面两条是屁话,但有时候它真的是解决问题的最好方法。3 [; f, c5 q' C! Z5 m
    1、改用更有效的算法% j1 L4 @1 H0 c1 p
    2、采用Mex技术,或者利用matlab提供的工具将程序转化为C语言、Fortran语言。

    # E- l' s. n* V% \

    4 w' `( K/ X( |1 `- P% M' Y  来源:iLoveMatlab
    , q2 [% q0 G' o' E) [! M6 Y) a- T+ V+ Q3 E
    7 L- N/ J3 J! W7 }
    在这里本人推荐使用‘绝招’。
    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, 2025-8-19 23:57 , Processed in 0.889590 second(s), 101 queries .

    回顶部