QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 4503|回复: 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 编辑 2 l! Z5 o2 n. C4 M8 N  d' y3 E4 J  I1 ^

    8 |2 {/ z. q( U) I3 K, q6 }加速matlab运行的三重境界

    加速matlab运行的三重境界+ G3 ]9 L' v" ^# {4 `9 l5 d  J
    %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%" R, [( V) S9 E  Q$ M4 J6 M6 S9 N
    %%%%%%%%%%%%%%%%%%%%%%%
    2 j4 s8 l& g6 s6 Q# i
    一、 遵守Performance Acceleration的规则* w+ u' L! ^* J& {) a
    二、 遵守三条规则
    # |1 \2 X; H; @9 n! \. ~7 v) J. u  V三、 绝招' m& @( L1 s% R/ i9 [7 N
    %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
    $ M+ n) [% \0 P) ?$ _%%%%%%%%%%%%%%%%%%%%%%%

    一、 遵守Performance Acceleration的规则) }8 I' E' u1 Y" V3 z$ x& P8 h
    关于什么是“Performance Acceleration”请参阅matlab的帮助文件。我只简要的将
    , x4 F3 ~2 a4 z" G. O2 N+ @其规则总结如下7条:
    ! a  r' Q2 r: x% ^5 q; _1、只有使用以下数据类型,matlab才会对其加速:
    & J+ v1 c) @4 U+ o% e- T2 R& Zlogical,char,int8,uint8,int16,uint16,int32,uint32,double% m& C7 Z' C& a
    而语句中如果使用了非以上的数据类型则不会加速,如:numeric,cell,structu
    ( A* z1 I0 R/ Q6 h6 dre,single,! H2 W3 I# ^7 @4 \
    function handle,java classes,user classes,int64,uint646 N2 Z: i  S8 ?* z5 H
    2
    matlab不会对超过三维的数组进行加速。
    + y" t) m0 [; ]+ r9 v$ w% V
    3、当使用for循环时,只有遵守以下规则才会被加速:afor循环的范围只用标量值
    - `) p0 @* a$ b) U来表示;. t- y8 y+ i* P% M% P
    bfor循环内部的每一条语句都要满足上面的两条规则,即只使用支持加速的数3 F5 W- ?6 x3 J: E9 j& K
    据类型,只使用1 N$ _* [" Q! ^6 P
    三维以下的数组;c、循环内只调用了内建函数(build-in function)。
    3 G* @* E0 Z2 l4、当使用ifelseifwhileswitch时,其条件测试语句中只使用了标量值时,将
    . Z, n0 n% r$ K7 Z6 I加速运行。
    + F& \. m* @) S+ [5 U: R6 x6 D5、不要在一行中写入多条操作,这样会减慢运行速度。即不要有这样的语句:4 d2 h; j4 \6 E
    x = a.name; for k=1:10000, sin(A(k)), end;" X% s8 C- y  T, y9 k8 }1 U
    6
    、当某条操作改变了原来变量的数据类型或形状(大小,维数)时将会减慢运行速
    - Q7 a# D8 o# @# \' j2 [( G9 C  G9 |度。
    2 O* I$ ]' b- N/ y7、应该这样使用复常量x = 7 + 2i,而不应该这样使用:x = 7 + 2*i,后者会降低
    0 c0 @$ P+ G' Z( |4 K, u运行速度。
    # L& I5 R+ K. h4 f: c" [6 E- Z%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%: `5 |! j5 m* U) {
    %%%%%%%%%%%%%%%%%%%%%%%6 ]& x, p* p# B9 \
    二、 遵守三条规则
    8 P6 V* o/ z- u( G$ o- M1、尽量避免使用循环,MATLAB的文档中写到“MATLAB is a matrix language, whic2 A8 L+ @1 u7 C% }0 V( t, Q; d
    h means it is designed
    . ?" K. K$ h" n7 q/ F1 |( F, Zfor vector and matrix operations. You can often speed up your M-file c
    ! _( e# k9 r! D/ l; ^+ zode by using
    1 }+ o, h+ W9 V; L% w4 F* mvectorizing algorithms that take advantage of this design. Vectorizati
    7 o: ]+ v0 R$ }0 K& o1 Ton means converting1 v4 ?3 `) V1 ], b' N. i
    for and while loops to equivalent vector or matrix operations.”
    。改进
    8 r+ ~) _5 I5 X* s- \  T
    这样的状况有两种方法:
    7 V! F" ~9 H2 r( t& Ua、尽量用向量化的运算来代替循环操作。如将下面的程序:9 ]0 p1 H; x% g& N
    i=0;
    & k. V. O  j4 Y  d6 A6 `9 hfor t = 0:.01:10& }) p  H* t4 v* }
    i = i+1;$ e* V5 j/ ?4 s, S. C0 y( e* \
    y(i) = sin(t);: T8 E8 [$ {( J* L8 A2 P
    end1 w& O5 \  k" l7 x+ M3 G" Q
    替换为:: z6 _* R, }7 {4 S' m
    t = 0:.01:10;8 c% L8 r6 ]  P2 X4 q3 h6 q
    y = sin(t);" k/ ^; F3 ?# E6 ~9 I' J+ v
    速度将会大大加快。最常用的使用vectorizing技术的函数有:Alldiffi
    / d% K( b' j& cpermute
    permute
    - X' n+ F3 G& j$ m! u
    reshapesqueezeanyfindlogicalprodshiftdimsub2indcums& R9 @2 P1 C5 D+ t+ A0 R9 A$ _
    um
    ind2sub

    . v9 c0 g' {  ?7 bndgridrepmatsortsum 等。
    ( q* O9 N* ?( _- B* y9 A请注意matlan文档中还有这样一句补充:“Before taking the time to
    ; n  s) M$ @, q! qvectorize your code, read the section on Performance Acceleration., z) w# F/ i9 b  ]- i* z/ D
    You may be able to) t) H# p! X3 W, w, q, R
    speed up your program by just as much using the MATLAB JIT Accelera/ t5 N) n7 N( i# ^1 Z& t0 [9 a
    tor instead of$ U4 L! h: p" I! ~% n) n% F
    vectorizing.”
    。何去何从,自己把握。

    . q/ r$ c% y9 \3 [! u6 A4 _b、在必须使用多重循环时下,如果两个循环执行的次数不同,则在循环的外环执
    / G5 r: Z2 J& q3 e& ]/ k2 ^行循环次数少的,& {- }4 }, K; u9 t1 R
    内环执行循环次数多的。这样可以显著提高速度。6 A0 ~. D" j0 Y, _* S+ A
    2a、预分配矩阵空间,即事先确定变量的大小,维数。这一类的函数有zeroson3 v. V; R9 p8 I3 S( S
    es
    cellstruct

    & A4 R' l# ^6 `: S0 X4 }6 Arepmat等。  e# ^6 P4 i: `# l3 J
    b、当要预分配一个非double型变量时使用repmat函数以加速,如将以下代码:
    " B/ q* J( I6 `A = int8(zeros(100));
    $ l- s3 Z6 Z0 P. r1 c+ F6 V
    换成:
    7 ~. A3 `+ Y. z" @6 s9 {A = repmat(int8(0), 100, 100);
    4 ?% u" ^# j+ Z5 Z' t! _c
    、当需要扩充一个变量的大小、维数时使用repmat函数。0 L# R5 M4 R' w7 M( E) v8 @
    3a、优先使用matlab内建函数,将耗时的循环编写进MEX-File中以获得加速。
    ( n/ a4 o1 K/ Rb、使用Functions而不是Scripts
    # _  B5 S: }8 F  Q%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
    ( f5 [% y2 K0 c9 N# Y%%%%%%%%%%%%%%%%%%%%%%%
    $ b8 a% M) k. i, V6 n% T
    三、 绝招1 Y7 R9 U" t5 ?$ I' V
    你也许觉得下面两条是屁话,但有时候它真的是解决问题的最好方法。( h  S% a( Y0 e. a5 T* i  U
    1、改用更有效的算法
    8 G, T7 h' M1 y6 p- j! D; f2、采用Mex技术,或者利用matlab提供的工具将程序转化为C语言、Fortran语言。

    ( @5 u  L: ]* [# G2 R

    $ r  v' ^1 P; k0 H2 ^- g+ e6 Q# L  来源:iLoveMatlab* w" H: b+ a) i( i" q% p1 V
    / I( y8 J3 I9 ?1 L

    # r  r8 I/ e5 F2 b: l在这里本人推荐使用‘绝招’。
    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-4-10 02:49 , Processed in 0.745278 second(s), 100 queries .

    回顶部