QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 4343|回复: 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 O6 l$ ~* ^
    / }9 z! ?- r+ e6 h$ Q
    加速matlab运行的三重境界

    加速matlab运行的三重境界* }. ~2 b7 V" U; K: c5 u
    %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
    + Q6 l) U4 @6 \8 \/ E%%%%%%%%%%%%%%%%%%%%%%%
    $ n( k5 @% w- k1 D6 J# r
    一、 遵守Performance Acceleration的规则
    ( R! x* i( t6 o二、 遵守三条规则. `: j3 c2 |7 h6 c0 O5 m5 L7 R
    三、 绝招! G8 C. W  H" m6 d
    %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
    ' |& F% g, q) g) l* [( S5 v0 g, m%%%%%%%%%%%%%%%%%%%%%%%

    一、 遵守Performance Acceleration的规则+ c9 W. h$ r& y5 _2 {  I
    关于什么是“Performance Acceleration”请参阅matlab的帮助文件。我只简要的将
    $ }' V) l2 h; ~" k: v! Y1 Z其规则总结如下7条:- R# A$ a( X) n: F$ }0 t$ i
    1、只有使用以下数据类型,matlab才会对其加速:$ S- G5 d& @& u8 B3 x8 m
    logical,char,int8,uint8,int16,uint16,int32,uint32,double
    * R; O: [/ \% ]% q. W1 Z
    而语句中如果使用了非以上的数据类型则不会加速,如:numeric,cell,structu" y, w! \! x3 a8 R
    re,single,
    ' J# e' Q0 w0 H- ?" a' ofunction handle,java classes,user classes,int64,uint64
    , q* \: A* a6 C' `% S% Q& V( Q2
    matlab不会对超过三维的数组进行加速。
    & ?9 W7 B- Y: D3 w: _& @$ }( F; f
    3、当使用for循环时,只有遵守以下规则才会被加速:afor循环的范围只用标量值" D/ h. o  f% s/ ?( P* b' D( e7 m
    来表示;# J/ `& ^% F$ |( E
    bfor循环内部的每一条语句都要满足上面的两条规则,即只使用支持加速的数
    3 \# g" c9 d/ W) p据类型,只使用
    8 n* C5 h! L4 Y. K4 e( @) ~' `三维以下的数组;c、循环内只调用了内建函数(build-in function)。
    * Z! Q7 R) }( |4、当使用ifelseifwhileswitch时,其条件测试语句中只使用了标量值时,将
    . _' a7 x9 @( j# o8 |% ^加速运行。1 ?4 {) p! ]8 @9 k, c
    5、不要在一行中写入多条操作,这样会减慢运行速度。即不要有这样的语句:
    4 x- H7 @1 [" d' o0 z5 ]5 qx = a.name; for k=1:10000, sin(A(k)), end;
    ! m3 i0 r  A8 W8 G6 P# D  w) J5 P6
    、当某条操作改变了原来变量的数据类型或形状(大小,维数)时将会减慢运行速7 C1 P: H1 u6 H# J
    度。
    ) M4 @4 N% C' P- s" r7、应该这样使用复常量x = 7 + 2i,而不应该这样使用:x = 7 + 2*i,后者会降低0 w* S$ ~/ H2 E4 K, C' Y( Z& T
    运行速度。
    8 {/ B4 s: ?' V3 q5 q1 x%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
    " a5 H( A( k$ x, b/ m+ t1 {5 H%%%%%%%%%%%%%%%%%%%%%%%
    . M9 |% h. f9 v  u/ H
    二、 遵守三条规则+ t% G+ y' O, r# i- V
    1、尽量避免使用循环,MATLAB的文档中写到“MATLAB is a matrix language, whic
    - q( k  z5 N' Lh means it is designed
    " b- Z9 G% c* R2 q+ |; mfor vector and matrix operations. You can often speed up your M-file c% }/ T+ b- k* \, n
    ode by using
    + w/ H5 N4 R: k7 j9 rvectorizing algorithms that take advantage of this design. Vectorizati7 [) o0 g4 A# v7 A  F2 Y
    on means converting
    + T/ O! ]- k) j' L$ v$ cfor and while loops to equivalent vector or matrix operations.”
    。改进

    9 b) S" L/ T& c' U* h这样的状况有两种方法:
    7 M. j% a* c2 F3 D2 Ta、尽量用向量化的运算来代替循环操作。如将下面的程序:% f$ d0 z- I, k; `2 A* l; n
    i=0;$ {& G3 v# B2 d) H$ I5 _! z/ R% i
    for t = 0:.01:10
      z; J; m0 e8 R. c3 Bi = i+1;
    1 D! C  j5 ?$ I9 Zy(i) = sin(t);- P' v% {$ K6 B8 \. m9 v
    end
    ; M0 d$ k% ^/ z. i% Y( `
    替换为:
    . ^8 P/ o. g. H4 y6 Ft = 0:.01:10;
    ' F; [5 @" A5 R: Y# i% b! \% G% \y = sin(t);
    : ]: O0 y9 q9 N, j7 B+ c8 j5 k. H
    速度将会大大加快。最常用的使用vectorizing技术的函数有:Alldiffi
    4 d7 L3 J; \% ?2 |3 \) |permute
    permute
    " v1 L5 v2 z0 n' d1 N2 O
    reshapesqueezeanyfindlogicalprodshiftdimsub2indcums
    . {+ Y2 B/ R  x, sum
    ind2sub
    ; l; t5 j' q, Z" B
    ndgridrepmatsortsum 等。
    9 A9 y1 L0 L$ W# ^7 W# T请注意matlan文档中还有这样一句补充:“Before taking the time to8 U9 Z7 r  H9 |2 ^0 M
    vectorize your code, read the section on Performance Acceleration.
    0 ~( z# y4 \: l/ H  r# aYou may be able to, F, p1 R  Z) y- q2 X4 L# S4 Y
    speed up your program by just as much using the MATLAB JIT Accelera
    $ x; l: k; P2 {8 _tor instead of
    # C5 d8 l& r/ Jvectorizing.”
    。何去何从,自己把握。
    3 D! N3 w3 |' q) T$ ?8 O( s# j( g
    b、在必须使用多重循环时下,如果两个循环执行的次数不同,则在循环的外环执9 `8 s6 E2 m% h7 T! A& R: b/ g
    行循环次数少的,) s/ A" {% D  N
    内环执行循环次数多的。这样可以显著提高速度。
    + m4 J% S$ e/ n5 E' G6 {2a、预分配矩阵空间,即事先确定变量的大小,维数。这一类的函数有zeroson- Y8 U" ~) R3 S$ \
    es
    cellstruct
    1 s! b9 k7 Z* }( q
    repmat等。; x' H3 g: x) B+ B  j% p5 H
    b、当要预分配一个非double型变量时使用repmat函数以加速,如将以下代码:# Q: h/ ~. K; c0 |1 z# f
    A = int8(zeros(100));
    ( b' Q- ^; c. _  [4 h2 v* i
    换成:
    # `% Y2 B- u% C1 a8 oA = repmat(int8(0), 100, 100);: X3 N+ Q0 q$ p
    c
    、当需要扩充一个变量的大小、维数时使用repmat函数。7 }5 a6 k' a- |/ n1 T
    3a、优先使用matlab内建函数,将耗时的循环编写进MEX-File中以获得加速。
    ! ^* M  ?7 a( wb、使用Functions而不是Scripts
    3 B7 T: G! t" z% U, j%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%  b# k) c/ K) V* u
    %%%%%%%%%%%%%%%%%%%%%%%
    $ Y; Y2 d0 Q: G( a6 x+ S: v/ ~# Y
    三、 绝招
    7 y$ ~  R6 ~: w5 W1 T: R你也许觉得下面两条是屁话,但有时候它真的是解决问题的最好方法。
    8 _" _7 h8 X  o: T$ Z  c& c1、改用更有效的算法
    / X3 V1 M4 ]* t2、采用Mex技术,或者利用matlab提供的工具将程序转化为C语言、Fortran语言。


    8 n5 H7 D1 r: U
    # f& {5 y$ |' U) g" D2 o! y  来源:iLoveMatlab
    ) V5 c0 n. O( ?* y/ M) S" t+ {, Q7 e8 t, {( T2 W/ H# m

    3 b& v* \; l' w: U6 ~0 I1 E在这里本人推荐使用‘绝招’。
    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-22 17:10 , Processed in 0.744797 second(s), 100 queries .

    回顶部